# O-O NUCLEI # Bumblebee Processor Core Instruction Architecture Manua1 # revise history | versio<br>n<br>number | Revision<br>date | Revised<br>chapter | Revised<br>content | |-----------------------|------------------|--------------------|--------------------| | 1.0 | 2019/6/21 | N/A | Initial version | # table of Contents | revise history | 2 | |----------------------------------------------------------|----| | List of forms | 9 | | Picture list | 10 | | 1. Bumblebee kernel instruction set and csr introduction | 10 | | 1.1. Introduction to the risc-v instruction set | 11 | | 1.2. Bumblebee kernel support instruction set | 11 | | 1.3. Csr register | 11 | | 2. Bumblebee kernel privilege architecture introduction | 12 | | 2.1. General introduction | 12 | | 2.2. Privileged mode | 12 | | 2.2.1. Machine Mode (Machine Mode) | 12 | | 2.2.2. User Mode | 12 | | 2.2.3. Machine Sub-Mode | 13 | | <b>2.2.4.</b> Mode view | 13 | | 2.2.5. Machine Mode to User Mode Switch | 14 | | 2.2.6. User Mode to Machine Mode Switch | 15 | | 2.2.7. Interrupt, exception, nmi nesting | 15 | | 2.3. Physical memory protection (pmp) | 16 | | 3. Bumblebee kernel exception mechanism introduction | 16 | | 3.1. Abnormal overview | 16 | | 3.2. Abnormal shielding | 17 | | 3.3. Abnormal priority | 17 | | 3.4. Enter exception handling mode | 17 | | 3.4.1. Execute from the PC address defined by mtvec | 18 | | 3.4.2. Update CSR register mcause | 18 | | 3.4.3. Update CSR register mepc | 19 | | 3.4.4. Update CSR register mtval | 20 | | 3.4.5. Update the CSR register mstatus | 20 | | 3.4.6. Update Privilege Mode | 20 | | 3.4.7. Update Machine Sub-Mode | 21 | | 3.5. Exit exception handling mode | 21 | | | 3.5.1. Execute from the PC address defined by mepc | . 22 | |----|-----------------------------------------------------|------| | | 3.5.2. Update the CSR register mstatus | . 22 | | | 3.5.3. Update Privilege Mode | . 23 | | | 3.5.4. Update Machine Sub-Mode | . 23 | | | 3.6. Exception service program | . 24 | | | 3.7. Abnormal nesting | . 24 | | 4. | Bumblebee kernel nmi mechanism introduction | . 25 | | | 4.1. Nmi overview | . 25 | | | 4.2. Nmi shielding | . 25 | | | 4.3. Enter nmi processing mode | . 25 | | | 4.3.1. Execute from the PC address defined by mnvec | . 26 | | | 4.3.2. Update CSR register mepc | . 26 | | | 4.3.3. Update CSR register mcause | . 27 | | | 4.3.4. Update the CSR register mstatus | . 27 | | | 4.3.5. Update Privilege Mode | . 27 | | | 4.3.6. Update Machine Sub-Mode | . 28 | | | 4.4. Exit nmi processing mode | . 28 | | | 4.4.1. Execute from the PC address defined by mepc | . 29 | | | 4.4.2. Update the CSR register mstatus | . 29 | | | 4.4.3. Update Privilege Mode | . 30 | | | 4.4.4. Update Machine Sub-Mode | . 30 | | | 4.5. Nmi service program | . 30 | | | 4.6. Nmi/abnormal nesting | . 31 | | | 4.6.1. Enter nmi/exception nesting | . 31 | | | 4.6.2. Exit nmi/exception nesting | . 33 | | 5. | Bumblebee kernel interrupt mechanism introduction | . 35 | | | 5.1. Interrupt overview | . 35 | | | 5.2. Interrupt controller eclic | 35 | | | 5.3. Interrupt type | . 36 | | | <b>5.3.1.</b> External Interrupt | . 36 | | | 5.3.2. Internal interrupt | . 36 | | | 5.4. Interrupt mask | . 37 | | | 5.4.1. Interrupt global mask | | | | 5.4.2 Interrupt course congretaly chielded | 27 | | 5.5. Interrupt level, priority and arbitration | 38 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------| | 5.6. Enter interrupt processing mode | 38 | | 5.6.1. Execute from the new pc address | 39 | | 5.6.2. Update Privilege Mode4 | <b>4</b> 0 | | 5.6.3. Update Machine Sub-Mode4 | <b>4</b> 0 | | 5.6.4. Update CSR register mepc | <i>40</i> | | 5.6.5. Update the CSR registers meause and mstatus4 | <i>40</i> | | 5.7. Exit interrupt processing mode | 12 | | 5.7.1. Execute from the PC address defined by mepc4 | <i>43</i> | | 5.7.2. Update the CSR registers meause and mstatus4 | <i>43</i> | | 5.7.3. Update Privilege Mode4 | 14 | | 5.7.4. Update Machine Sub-Mode4 | 14 | | 5.8. Interrupt vector table | 14 | | 5.9. Context save and restore of incoming and outgoing interrupts4 | 15 | | 5.10. Interrupt response delay | <del>1</del> 6 | | 5.11. Interrupt nesting | <del>1</del> 6 | | 5.12. Interrupted biting | <del>1</del> 7 | | 5.13. Interrupted vector processing mode and non-vector processing mode | 18 | | 5.13.1. Non-vector processing mode4 | <b>4</b> 8 | | 5.13.2. Vector processing mode | 54 | | 6. Bumblebee kernel timer and eclic | 58 | | 6.1. Timer introduction | 58 | | 6.1.1. Introduction to timer | 58 | | 6.1.2. Timer register | 58 | | 6.1.3. Timing through the mtime register | 59 | | 6.1.4. Pause timer through mstop register5 | 59 | | 6.1.5. Generate timer interrupts via the mtime and mtimecmp registers | 59 | | 6.1.6. Generate software interrupts via msip register6 | 50 | | 6.2. Eclic introduction | 50 | | <b>6.2.1.</b> Introduction to eclic | | | | 51 | | 6.2.2. Eclic interrupt target | | | | 52 | | 6.2.2. Eclic interrupt target | 52<br>53 | | 6.2.2. Eclic interrupt target | 52<br>53<br>53 | | 6.2.2. Eclic interrupt target | 52<br>53<br>53<br>9) | | 6.2.2. Eclic interrupt target 6 6.2.3. Eclic interrupt source 6 6.2.4. Eclic interrupt source number (id) 6 6.2.6. Eclic register 64 Eclic interrupt source enable bit (ie 67) | 62<br>63<br>63<br>e) | | 6.2.10. Vector or Non-Vector Mode of ECLIC Interrupt Sources | 71 | |------------------------------------------------------------------|----| | 6.2.11. Eclic interrupt target threshold level | 71 | | 6.2.12. Arclic interrupt arbitration mechanism | 71 | | 6.2.13. Eclic interrupt response, nesting, tail biting mechanism | 72 | | 7. Bumblebee kernel csr register introduction | 73 | | 7.1. Bumblebee kernel csr register overview | 73 | | 7.2. Bumblebee kernel csr register list | 73 | | 7.3. Access to the cumbler register of the bumblebee kernel | 75 | | 7.4.Risc-v standard csr supported by bumblebee kernel | 76 | | 7.4.1. misa | 76 | | 7.4.2. mie | 77 | | 7.4.3. mvendorid | 77 | | 7.4.4. marchid | 78 | | 7.4.5. mimpid | 78 | | <b>7.4.6.</b> mhartid | 78 | | <b>7.4.7.</b> mstatus | 78 | | 7.4.8. MIE domain of mstatus | 79 | | 7.4.9. MPIE and MPP domains for mstatus | 79 | | 7.4.10. FS domain of mstatus | 80 | | 7.4.11. XS domain of mstatus | 81 | | 7.4.12. SD domain of mstatus | 81 | | 7.4.13. mtvec | 82 | | 7.4.14. mtvt | 82 | | 7.4.15. mscratch | 83 | | 7.4.16. mepc | 83 | | 7.4.17. mcause | 84 | | 7.4.18. mtval (mbadaddr) | 85 | | 7.4.19. mip | 85 | | 7.4.20. mnxti | 85 | | 7421 mintstatus | 86 | | 7.4.22. mscratchesw | 86 | |---------------------------------------------------|------| | 7.4.23. mscratcheswl | 87 | | 7.4.24. Mcycle and mcycleh | 88 | | 7.4.25. Minstret and minstreth | 88 | | 7.4.26. Cycle and cycleh | 89 | | 7.4.27. Instret and intreth | 89 | | <b>7.4.28.</b> Time and timeh | 89 | | 7.4.29. mcounteren | 89 | | 7.5. Bumblebee kernel custom csr | 90 | | 7.5.1. mcountinhibit | 90 | | 7.5.2. mnvec | 90 | | 7.5.3. msubm | 91 | | 7.5.4. mmisc_ctl | 91 | | 7.5.5. msavestatus | 92 | | 7.5.6. Msaveepc1 and msaveepc2 | 92 | | 7.5.7. Msavecause1 and msavecause2 | 93 | | 7.5.8. pushmsubm | 93 | | 7.5.9. mtvt2 | 93 | | 7.5.10. jalmnxti | 94 | | 7.5.11. pushmcause | 94 | | 7.5.12. pushmepc | 94 | | 7.5.13. sleepvalue | 95 | | 7.5.14. txevt | 95 | | 7.5.15. wfe | 96 | | Bumblebee kernel low power mechanism introduction | 97 | | <b>8.1.</b> Go to sleep | 97 | | 8.2. Exit hibernation | 98 | | 8.2.1. Nmi wake up | . 98 | | 8.2.2. Interrupt wakeup | . 98 | | 8.2.3. Event wake up | . 99 | | 8.2.4. Debug wake up | . 99 | | 8.3. Wait for interrupt mechanism | 99 | | 8.4 Wait for event mechanism | 99 | 8. # List of forms | Table 3-1 The exception code in the mcause register | . 19 | |-------------------------------------------------------------------|------| | Table 6-1 Memory Map Addresses of the timer Register | 58 | | Table 6-2 Bit field of register mstop | 59 | | Table 6-3 Bit field of register msip | 60 | | Table 6-4 eclic interrupt source number and assignment | 63 | | Table 6-5 Intra-cell address offset of the eclic register | 64 | | Table 6-6 Bit field of register cliccfg | 65 | | Table 6-7 Bit field of register clicinfo | 65 | | Table 6-8 Bit field of register mth | 66 | | Table 6-9 Bit field of register clicintip[i] | 66 | | Table 6-10 Bit field of register clicintip[i] | 66 | | Table 6-11 Bit fields of the register clicintattr[i] | 66 | | Table 7-1 List of csr registers supported by the bumblebee kernel | 73 | | Table 7-2 Control bits of the mstatus register | 79 | | Table 7-3 mtvec Register Control Bits | 82 | | Table 7-4 mtvt alignment | 83 | | Table 7-5 Control bits of the mepc register | 84 | | Table 7-6 Control bits of the mcause register | 84 | | Table 7-7 Control bits of the minstatus register | 86 | | Table 7-8 mCounteren Register Control Bits | 89 | | Table 7-9 Control bits of mcountinhibit register | 90 | | Table 7-10 msubm Register Control Bits | 91 | | Table 7-11 Control bits of the mmisc_ctl register | 92 | | Table 7-12 msavestatus Register Control Bits | 92 | | Table 7-13 mtvt2 register control bits | 94 | | Table 7-14 sleepvalue register control bits | 95 | | Table 7-15 txevt Register Control Bits | 95 | | Table 7-16 Control bits of the wfe register | 96 | | | Picture | |--------------------------------------------------|------------------------------------------------------------------------| | Figure 3-1 Overall process of abnormal re | esponse | | Figure 3-3 Exiting the abnormal overall p | process | | Figure 4-1 The overall process of nmi re | sponse | | Figure 4-2 Changes to the csr register wh | hen entering/exiting nmi | | Figure 4-3 Exiting the overall process of | f nmi | | Figure 4-4 Schematic diagram of the two- | level nmi/exception state stacking mechanism of the bumblebee kernel31 | | Figure 5-1 Schematic diagram of the inte | rrupt type | | Figure 5-2 Schematic diagram of interrup | t arbitration | | Figure 5-3 Overall response to the inter | rupt | | Figure 5-4 Changes to the csr register wh | hen entering/exiting an interrupt42 | | Figure 5-5 Overall process of exiting the | e interrupt43 | | Figure 5-6 Schematic diagram of the inter | rrupt vector table45 | | Figure 5-7 Schematic diagram of interrup | t nesting | | Figure 5-8 Schematic diagram of interrup | t bite | | Figure 5-9 Example of interrupted non-vec | ctor processing mode (always nesting is always supported)50 | | Figure $5-10$ Three successive (non-vector | processing mode) interrupts form a nest | | Figure 5-11 Schematic diagram of interru | pt bite53 | | Figure 5-12 Example of vector processing | mode for interrupts54 | | Figure 5-13 Example of vector processing | mode for interrupts (support interrupt nesting) | | Figure 5-14 Three successive (vector prod | cessing mode) interrupts form a nest | | Figure 6-1 eclic logical structure diagra | am | | Figure 6-2 eclic relationship structure o | diagram | | Figure 6-3 Example format of the register clicin | tetl[i] | | | value of level | | Figure 6-5 Several examples of cliccfg se | ettings | | Figure 7-1 A subset of the modular instru | uctions represented by the lower 26 bits of the misa register77 | | Figure 7-2 Status code represented by the | e fs field | list #### 1. Bumblebee kernel instruction set and CSR introduction The Bumblebee Processor Core, or Bumblebee core, is a commercial custom made by Nuclei System Technology in conjunction with Gigadevice for its general purpose MCU products for IoT or other ultra-low power scenarios. RISC-V processor core. For an introduction to the hardware features of the Bumblebee kernel, see the Bumblebee Kernel Concise Data Sheet. This article provides a detailed introduction to the supported instruction architecture. # Note: The Bumblebee core used for this MCU is jointly developed by Nuclei System Technology and Taiwanese Andes Technology, and Nuclei System Technology provides authorization and technical support services. At present, Nuclei System Technology can license the mass-proven N200 series of ultra-low-power commercial processor cores, as well as research a variety of high-performance embedded processor series, and provide customers with customized services. # 1.1. Introduction to the risc-v instruction set The standard RISC-V instruction set document version followed by the Bumblebee kernel is: "Instruction Set Document Version 2.2" (riscv-spec-v2.2.pdf). Users can register on the RISC-V Foundation website to follow and download the full text (free of charge) # (https://riscv.org/specifications/) . In addition to the risc-v "instruction set document version 2.2" English original text, users can also refer to the Chinese book "Teach you to design cpu - risc-v processor articles" appendix a, appendix c ~ g part, its use of popular The easy-to-understand Chinese systematically explains the risc-v instruction set standard. The RISC-V instruction set is based on a modular design that can be flexibly combined according to configuration. The Bumblebee kernel supports the following modular instruction set: - Rv32 architecture: 32-bit address space, general-purpose register width 32 bits. - i: Supports 32 general integer registers. - m: support integer multiplication and division instructions - c: Supports compression instructions with a code length of 16 bits to increase code density. - a: Support atomic operation instructions. According to the risc-v architecture naming convention, the combination of the above subset of instructions can be expressed as rv32imac. ## 1.3. Csr register age II the processor core and uses its proprietary 12-bit address encoding space. See Chapter 7 for details. ### 2. Introduction to the Bumblebee kernel privilege architecture #### 2.1. General introduction The standard RISC-V privilege schema document version followed by the Bumblebee kernel is: "Privilege Architecture Document Version 1.10" (riscv-privileged-v1.10.pdf). Users can register on the RISC-V Foundation website to follow and download the full text (free of charge) (https://riscv.org/specifications/). In addition to the risc-v "privileged architecture document version 1.10" English original text, users can also refer to the Chinese book "Hands to teach you design cpu - risc-v processor articles" appendix a, appendix c ~ g part, its use of popular The easy-to-understand Chinese systematically explains the risc-v privilege architecture standard. #### 2.2. Privilege Modes The Bumblebee kernel supports two privileged modes (Privilege Modes): - Machine Mode is a required mode, and the code of this Privilege Mode is 0x3. - User Mode is a configurable mode, and the code for this Privilege Mode is 0x0. #### 2.2.1. Machine Mode (Machine Mode) The key points of the Bumblebee kernel about Machine Mode are as follows: - After the processor core is reset, it defaults to Machine Mode. - In Machine Mode, the program has access to all CSR registers. #### 2.2.2. User Mode Only User Mode qualified CSR registers can be accessed in User Mode, see Section 7.3 for details. #### 2.2.3. Machine Sub-Mode The Machine Mode of the Bumblebee kernel may be in four different states, called the machine submode. #### (Machine Sub-Mode): - Normal machine mode (the encoding of the Machine Sub-Mode is 0x0): - After the processor core is reset, it is in this submode. If no exception, nmi, or interrupt is generated after the processor is reset, it will continue to operate normally in this mode. - Exception handling mode (the encoding of the Machine Sub-Mode is 0x2): - The processor core is in this state after responding to an exception. - See Chapter 3 for details on the exception mechanism. - NMI processing mode (the encoding of the Machine Sub-Mode is 0x3): - The processor core is in this state in response to the nmi. - See Chapter 4 for details on the nmi mechanism. - Interrupt processing mode (the encoding of the Machine Sub-Mode is 0x1): - The processor core is in this state after responding to the interrupt. - See Chapter 5 for details on the interrupt mechanism. The Machine Sub-Mode currently in the processor core is reflected in the TYP field of the CSR register msubm, so software can read the currently in the Machine Sub-Mode by reading this CSR register. For details on the msubm register, see Section 7.5.3. Note: In the RISC-V architecture, entry exceptions, NMIs, or interrupts are also collectively referred to as traps. 2.2.4. Mode view Page 20 The key points of the processor mode view are as follows: - According to the architecture definition of RISC-V, the current Machine Mode or User Mode of the processor is not reflected in any software-visible registers (the processor core maintains a hardware register that is invisible to the software), so the software program cannot read it. Look at any of the registers to see the current Machine Mode or User Mode. - The four machine sub-modes of the Bumblebee kernel are reflected in the CSR register msubm In the TYP domain, the software can view the currently in the Machine Sub-Mode by reading this CSR register. #### 2.2.5. Machine Mode to User Mode Switch The mret instruction can be executed directly in Machine Mode. Switching from Machine Mode to User Mode is only possible The execution of the mret instruction occurs. Since the Mode Mode may be in four different states as described in Section 2.2.32.2.3, # Introduced as follows: Page 20 ■ If in normal machine mode, the hardware behavior of executing the mret instruction is the same as executing the mret instruction in exception handling mode, see Section 3.5 for details. • Therefore, if you want to switch from Machine Mode to User Mode in normal machine mode, you need to modify the value of MTP field in mstatus first, and then execute the mret instruction to achieve the effect of mode switching. A typical program code snippet looks like this: - If the hardware behavior of the mret instruction is executed in exception handling mode, see Section 3.5 for details. - In general, the mret instruction is used to exit from exception handling mode to the mode before entering the exception. - If you explicitly want to exit from Machine Mode to User Mode (or normal machine mode), you need to modify the value of mstatus' MPP field first, and then execute the mret instruction to achieve the mode switch effect. - If the hardware behavior of the mret instruction is executed in interrupt processing mode, see Section 5.7 for details. - In general, the mret instruction is used to exit from interrupt processing mode to the mode before entering the interrupt. Page 14 - If you explicitly want to exit from Machine Mode to User Mode (or normal machine mode), you need to modify the value of mstatus' MPP field first, and then execute the mret instruction to achieve the mode switch effect. - If the hardware behavior of the mret instruction is executed in NMI processing mode, see Section-4.4 for details. - In general, the mret instruction is used to exit from NMI processing mode to normal machine mode. - If you explicitly want to exit from Machine Mode to User Mode (or normal Page 20 machine mode), you need to modify the value of mstatus' MPP field first, and # note: Executing the mret instruction directly in User Mode will generate an Illegal Instruction exception #### 2.2.6. User Mode to Machine Mode Switch Switching from the User Mode to the Machine Mode of the Bumblebee kernel can only occur via exceptions, response interrupts, or NMI: - The response exception enters the exception handling mode. See Section 3.4 for details. - Note: The software can force the ecall exception handler by calling the ecall instruction. - The interrupt processing mode is entered in response to the interrupt. See Section 5.6 for details. - In response to nmi enter the nmi processing mode. See section 4.3 for details. ### 2.2.7. Interrupt, exception, nmi nesting # Interrupts and exceptions can nest themselves, and nmi can't nest itself: - In mmi processing mode, if mmi occurs again, the new mmi will be masked, so mmi cannot self-nesert, see section 4.6 for details. - In exception handling mode, if an exception occurs again, this is an abnormal nesting situation, see Section 3.73.7 for information. (in (in In interrupt processing mode, if an interrupt occurs again, this is an interrupt nesting situation, see Section 5.15.11. Setting Page 15 Solve the details. # Interrupts, exceptions, and nmis may also nest with each other, as follows: - When an exception occurs in the interrupt processing mode, the exception processing mode is entered. - If an exception occurs in the nmi processing mode, the exception handling mode is entered. - When nmi occurs in the interrupt processing mode, it enters the nmi processing mode. - When nmi occurs in the exception handling mode, it enters the nmi processing mode. - Note: In mmi and exception mode, the default interrupt bit is automatically turned off by the hardware, so it will not respond to the interrupt. In order to be able to guarantee that the exception and the NMI can be restored to the previous state (Recoverable) after they are nested with each other, The Bumblebee kernel implements a "Two Levels of NMI/Exception State Save Stacks" technique, see Section 4.6 for more details. 2.3. Physical memory protection (pmp) Since the Bumblebee core is a low-power core for the microcontroller domain, it does not support virtual address management units. (Memory Management Unit), so all address access operations are physical addresses used. In order to isolate and protect permissions based on different memory physical address ranges and different Privilege Modes, the RISC-V architecture standard defines a physical memory protection mechanism (Physical Memory Protection (PMP) unit. Note: The Bumblebee kernel does not support PMP units. - 3. Bumblebee kernel exception mechanism introduction - 3.1. Abnormal overview Exception mechanism, that is, the processor core suddenly encounters an abnormal event in the process of sequentially executing the program instruction stream and aborts execution of the current program, and then processes the exception instead. The main points are as follows: Page 20 exception. An exception is caused by an internal event in the processor or an event in the execution of the program, such as a hardware failure, a program failure, or the execution of a special system service instruction. In short, it is an internal cause. ■ After the exception occurs, the processor enters the exception service handler. ## 3.2. Abnormal shielding The exception specified in the risc-v architecture cannot be masked, which means that once an exception occurs, the processor will stop the current operation and enter the exception handling mode. ## 3.3. Abnormal priority There may be multiple instances of exceptions in the processor core, so exceptions also have priority. The priority of the exception is as <a href="mailto:Table">Table</a> Table 3-1 As shown in the figure, the smaller the exception number, the higher 设置 the priority of the exception. # 3.4. Enter exception handling mode When entering an exception, the hardware behavior of the Bumblebee kernel can be briefly described as follows. Note that the following hardware behavior is done simultaneously in one clock cycle: - The execution of the current program flow is stopped and the execution begins with the PC address defined by the CSR register mtvec. - Update the relevant csr registers, which are the following registers: - mcause (Machine Cause Register) - mepc (Machine Exception Program Counter) - mtval (Machine Trap Value Register ) - mstatus (Machine Status Register) - Update the Privilege Mode of the processor core and the Machine Sub-Mode. # The overall process of abnormal # response<u>Figure 3-1 Figure 3-1 Shown.</u> <u> ۲</u>۲. 🗷 设置 These will be detailed below. # 3.4.1. Execute from the PC address defined by mtvec The PC address that the Bumblebee kernel jumps after encountering an exception is specified by the CSR register mtvec. The mtvec register is a readable and writable CSR register, so the software can programmatically change the value. The detailed format of the mtvec register is shown in Table 7-3 in Table 7-3. # 3.4.2. Update CSR register meause When the Bumblebee kernel enters an exception, the CSR register meause is updated (hardware automatically) to reflect the current type of exception. The software can read this register to query the specific cause of the exception. The detailed format of the mcause 20 register is shown in Table 7-6, Table 7-6, where the lower 5 bits are the exception number field, which is used to indicate various types. The same type of exception, such as Table 3-1 Table 3-1 Shown. 设置 Table 3-1 Exception Code in the mcause Register | Exception<br>number<br>(Exception<br>Code) | Exception and interrupt type | Synchrono<br>us<br>Asynchron<br>ous | desc<br>ript<br>ion | |--------------------------------------------|--------------------------------------------------------------------------------------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0 | Instruction address<br>misaligned | Synchronize | The instruction pc address is not aligned. Note: This exception type is configured with the "c" extension It is not possible to have a subset of instructions in the processor. | | 1 | Instruction access error (Instruction access fault) | Synchronize | Fetch instruction fetch error. | | 2 | Illegal instruction (Illegal instruction) | Synchronize | Illegal order. | | 3 | Breakpoint | Synchronize | The RISC-V architecture defines the EBREAK instruction, which occurs when the processor executes the instruction and enters the exception service routine. This instruction is often used by the debugger (Debugger). Break point | | 4 | Read memory address<br>misaligned | Synchronize | The Load instruction fetch address is not aligned. Note: The Bumblebee kernel does not support data memory read and write operations with unaligned addresses, so This exception is raised when the access address is not aligned. | | 5 | Read memory access error<br>(Load<br>access fault) | Inexact<br>asynchronous | Load instruction fetch error. | | 6 | Write memory and amo<br>address are not aligned<br>(Store/AMO address<br>misaligned) | Synchronize | The Store or AMO instruction fetch address is not aligned. Note: The Bumblebee kernel does not support data memory read and write operations with unaligned addresses, so this happens when the access address is not aligned. often. | | 7 | Write memory and amo access<br>error<br>(Store/AMO access fault) | Inexact<br>asynchronous | Store or AMO instruction fetch error. | | _ | | | | |----|----------------------------|-------------|-----------------------------------| | 8 | User mode environment call | Synchronize | The ecall instruction is | | | (Environment call from | | executed in User Mode. The RISC-V | | | U-mode) | | architecture defines the ecall | | | | | instruction, which occurs when | | | | | the processor executes the | | | | | instruction. | | | | | Into the exception service | | | | | program. This instruction is | | | | | often used by software to force | | | | | entry into the exception mode. | | 11 | Machine mode environment | Synchronize | Execute the ecall command in | | | call | | Machine Mode. The RISC-V | | | (Environment call from | | architecture defines an ecall | | | M-mode) | | instruction that, when executed | | | | | by the processor, will cause an | | | | | exception to enter the exception | | | | | service routine. This instruction | | | | | is often used by software | | | | | Use, forcibly enter the abnormal | | | | | mode. | # 3.4.3. Update CSR register mepc The return address of the Bumblebee kernel when exiting the exception is determined by the CSR register mepc (Machine Exception Program Counter) Save. When an exception is entered, the hardware will automatically update the value of the mepc register, which will be used as the return address for the exit exception. After the exception is over, it can use its saved PC value to return to the program point that was previously stopped. note: - When an exception occurs, the value of the exception return address mepc is updated to the instruction PC where the exception occurred. - Although the mepc register is automatically updated by hardware when an exception occurs, the mepc register itself is a readable and writable register, so software can also write to it directly to modify its value. ### 3.4.4. Update CSR register mtval When the Bumblebee kernel enters an exception, the hardware will automatically update the CSR register mtval (Machine Trap Value Register) to reflect the memory access address or instruction encoding that caused the current exception: - If an exception is caused by a memory access, such as an exception caused by a hardware breakpoint, instruction fetch, or memory read and write, the address of the memory access is updated to the mtval register. - If the exception is caused by an illegal instruction, the instruction code of the instruction is updated to the mtval register. ## 3.4.5. Update the CSR register mstatus The detailed format of the mstatus register is shown in Table 7-2, Table 7-2. When the Bumblebee kernel enters an exception, the hardware will automatically update some fields of the CSR register mstatus (Machine Status Register): The value of the mstatus. MPIE field is updated to the value of the mstatus. MIE field before the exception occurred, as described in Sections 8.2 and 8.2. Shown. The role of the mstatus. MPIE field is to use the value of mstatus. MPIE to recover the mstatus. MIE value before the exception occurred after the Page 25 exception. - The value of the mstatus. MIE field is updated to 0 (meaning that the interrupt is globally closed after entering the exception service routine, all interrupts will be masked and not responding). - The value of the mstatus. MPP field is updated to the Privilege Mode before the exception occurred, as described in Sections 8.2 and 8.2. Show. The role of the mstatus. MPP field is to use the value of mstatus. MPP to recover the Privilege Mode before the exception occurred after the exception. mret退出异常 ## 3.4.6. Update Privilege Mode Exceptions need to be handled in Machine Mode. When entering an exception, the processor kernel's Privilege Mode Updated to machine mode. 设置 ## 3.4.7. Update Machine Sub-Mode occurred. The Machine Sub-Mode of the Bumblebee kernel is reflected in real time in the msubm. TYP field of the CSR register. When an exception is entered, the Machine Sub-Mode of the processor core is updated to the exception handling mode, so: ■ The value of the msubm. PTYP field of the CSR register is updated to the Machine Sub-Mode before the exception occurred. (The value of the msubm. TYP field), as described in Sections 8.2 and 8.2. The role of the msubm. PTYP domain is in the exception After the end, you can use the value of msubm. PTYP to recover the Machine Sub-Mode value before the exception ■ The value of the msubm. TYP field of the CSR register is updated to "Exception Handling Mode" as described in Sections 8.2 and 8.2. It is shown that the current mode is already in the "abnormal processing mode". Figure 3-2 Changes to the csr register when entering/exiting an exception # 3.5. Exit exception handling mode After the program completes the exception handling, it eventually needs to exit from the exception service. Since the exception handling is in Machine Mode, the software must use the mret instruction when exiting the exception. The hardware behavior of the processor after executing the mret instruction is as follows. Note that the following hardware behavior is done simultaneously in one clock cycle: - The execution of the current program flow is stopped and the execution begins with the PC address defined by the CSR register mepc. - Update the CSR register mstatus (Machine Status Register) as shown in Sections 8.2 and 8.2, and Update the Privilege Mode of the processor core and the Machine Sub-Mode. The overall process of exiting an anomaly Figure 3-3 Figure 3-3 Show. Figure 3-3 Exiting the abnormal overall process ## These will be detailed below. ### 3.5.1. Execute from the PC address defined by mepc When an exception is entered, the mepc register is updated simultaneously to reflect the instruction PC value at which the exception was encountered. Through this mechanism, it means that after execution of the the mret instruction, the processor returns to the PC address of the instruction that encountered the exception at that time, so that the program stream that was previously aborted can be executed. Note: You may need to use software to update the value of mepc before exiting the exception. For example, if an exception is generated by ecall or ebreak, the value of mepc is updated to ecall or ebreak to command its own PC. So if the exception returns, if you use it directly The mepc saved PC value as the return address will jump back to the ecall of ebreak instruction, causing an infinition (execution) The ecall or ebreak instruction causes the exception to be reentered. The correct way is to change the mepc to the next instruction in the exception handler. Since ecall/ebreak is now a 4-byte instruction, rewrite the setting mepc=mepc+4. ### 3.5.2. Update the CSR register mstatus The detailed format of the mstatus register is shown in Table 7-2 in Table 7-2. The hardware will automatically update the CSR after executing the mret instruction Some fields of the register mstatus: - The value of the mstatus. MIE field is restored to the value of the current mstatus. MPIE. - The value of the current mstatus.MPIE field is updated to 1. - The updated values of the mstatus. MPP domain are divided into the following two cases: - ullet When user mode U-mode is configured, mstatus. MPP is updated to 0x0. - When user mode U-mode is not configured, mstatus. MPP is updated to 0x11. When entering an exception, the value of mstatus. MPIE was updated to the mstatus. MIE value before the exception occurred, such as the section and the first Section 8.2 and Section 8.2. After the mret instruction is executed, the value of the mstatus. MIE field is restored to the value of mstatus. MPIE. Through this mechanism, it means that after the mret instruction is executed, the mstatus. MIE value of the processor is restored to the value before the exception occurred. (Assuming the previous mstatus.MIE value is 1, it means the interrupt was re-opened globally). ### 3.5.3. Update Privilege Mode When entering an exception, the value of mstatus. MPP was updated to the Privilege Mode before the exception occurred, while the mret was executed. After the instruction, the processor's Privilege Mode is restored to the value of mstatus. MPP, as described in Sections 8.2 and 8.2. Through this mechanism, the processor is guaranteed to return to the Privilege Mode of the processor before the exception occurred. ### 3.5.4. Update Machine Sub-Mode The Machine Sub-Mode of the Bumblebee kernel is reflected in real time in the msubm. TYP field of the CSR register. Executing After the mret instruction, the hardware will automatically restore the processor's Machine Sub-Mode to the value of the msubm. PTYP field: When an exception is entered, the value of the msubm. PTYP field is updated to the Machine Sub-Mode value before the exception occurred. After exiting the exception with the mret instruction, the hardware restores the value of the processor Machine Sub-Mode to The value of the msubm. PTYP field is shown in Figure 4-2 Figure 4-2. Through this mechanism, it means that after exiting the exception, the processor's Machine Sub-Mode is restored to the Machine Sub-Mode before the exception occurred. ### 3.6. Exception service program When the processor enters an exception, it starts executing a new program from the PC address defined by the mtvec register. The program is usually an exception service program, and the program can also decide to further by querying the jump exception number in the mcause (Exception Code). Specific exception service procedures. For example, when the value in the program query mcause is 0x2, it is known that exception is an illegal instruction error. (Illegal Instruction), so you can jump further to the illegal instruction error exception service subroutine. Note: Since there is no hardware to automatically save and restore context in the entry exception exception mechanism, exit the software needs to explicitly use the instructions (written in assembly language) for context saving recovery. Please understand this in conjunction with a complete exception service code example for the mcu chip. ### 3.7. Abnormal nesting The Bumblebee kernel supports two levels of NMI/Exception State Save Stacks. See Section 4.6 for more details. ### 4. Introduction to the Bumblebee kernel NMI mechanism ### 4.1. Nmi overview NMI (Non-Maskable Interrupt) is a input signal of special processor core, often used to indicate system-level emergency errors (such as external hardware failures, etc.). After encountering the NMI, the processor core should immediately abort execution of the current program and instead process the NMI error. ### 4.2. Nmi shielding The NMI in the Bumblebee kernel cannot be masked, which means that once the NMI occurs, the processor will stop the current operation and process the NMI. ### 4.3. Enter nmi processing mode When entering NMI processing mode, the hardware behavior of the Bumblebee kernel can be briefly described as follows. Note that the following hardware behavior is done simultaneously in one clock cycle: - The execution of the current program flow is stopped and the execution begins with the PC address defined by the CSR register mnvec. - Update the relevant csr registers, which are the following registers: - mepc (Machine Exception Program Counter ) - mstatus (Machine Status Register) - mcause (Machine Cause Register) - Update the Privilege Mode of the processor core and the Machine Sub-Mode. # The overall process of nmi response is shown in Figure 4-1 Figure 4-1. Figure 4-1 The overall process of nmi response These will be detailed below. 设置 4.3.1. Execute from the PC address defined by mnvec The PC address that the Bumblebee kernel jumps into after encountering the NMI is specified by the CSR register mnvec. The values of the mnvec register are as follows: ■ When mmisc\_ctl[9]=1, the value of the mnvec register is equal to mtvec, ie the NMI has the same Trap as the exception. Entrance address. • When mmisc\_ctl[9]=0, the value of the mnvec register is equal to reset\_vector, and the reset\_vector is the processor. The value of the PC after reset. ### 4.3.2. Update CSR register mepc The return address of the Bumblebee kernel when exiting the NMI is determined by the CSR register mepc (Machine Exception Program Counter) Save. Upon entering the NMI, the hardware will automatically update the value of the mepc register, which will be used as the exit NMI The return address, after the end of nmi, can use its saved pc value to return to the program point that was previously stopped. note: - When the MII occurs, the MII return address mepc is pointed to the next instruction that has not yet been executed (because the instruction at MII has been executed correctly). Then, after exiting the MII, the program will return to the previous program point and re-execute from the next instruction. - Although the mepc register is automatically updated by hardware when the NMI occurs, the mepc register itself is a readable and writable register, so the software can also write this register directly to modify its value. ### 4.3.3. Update CSR register meause The detailed format of the mcause register is shown in Table 7-6, Table 7-6. When the Bumblebee kernel enters the NMI, the hardware automatically saves the current trap ID to mcause to indicate the cause of the trap. Interrupts, exceptions, and NMIs have their own special Trap IDs. The NMI Trap ID has the following two values: ■ When mmisc\_ctl[9]=1, the NMI Trap ID is 0xfff. ■ When mmisc ctl[9]=0, the NMI Trap ID is 0xl. By assigning a specific Trap ID to each Trap, you can identify the cause of the Trap. The software can design a specific handler to process the Trap based on the cause of the Trap. ### 4.3.4. Update the CSR register mstatus The detailed format of the mstatus register is shown in Table 7-2, Table 7-2. When the Bumblebee kernel enters the NMI, the hardware will automatically update some fields of the CSR register mstatus: ■ The value of the mstatus. MPIE field is updated to the value of the mstatus. MIE field before the NMI occurs, such as Figure 4-2 Figure 4-2 Shown. The role of the mstatus. MPIE field is to recover the NMI using the value of mstatus. MPIE after the end of the NMI. # The mstatus. MIE value before the occurrence. - The value of the mstatus. MIE field is updated to 0 (meaning that the interrupt is globally closed after entering the NMI server and all interrupts will be masked and not responding). - The value of the mstatus. MPP field is updated to the Privilege Mode before the NMI occurs. When the role of the mstatus. MPP field is saved, after the NMI is finished, the value of mstatus. MPP can be used to recover the Privilege Mode before the NMI occurs. ### 4.3.5. Update Privilege Mode NMI processing is done in Machine Mode, so when entering NMI, the processor kernel's privileged mode (Privilege Mode) switches to machine mode. ### 4.3.6. Update Machine Sub-Mode The Machine Sub-Mode of the Bumblebee kernel is reflected in real time in the msubm. TYP field of the CSR register. Entering At NMI, the Machine Sub-Mode of the processor Price is updation. MMI msubm. TYP NMI processing mode, mset NMI The value of the msubm. PTYP field of the CSR register is updated to the Machine Sub-Mode before the NMI occurs. (the value of the msubm. TYP field), such as Figure 4-2 Figure 4-2 Shown. The role of the msubm. PTYP domain is at the end of the NMI After that, you can use the value of msubm. PTYP to recover the Machine Sub-Mode value before the NMI occurred. ■ The value of the msubm. TYP field of the CSR register is updated to "NMI processing mode" such as Figure 4.2 Figure 4.2 As shown 设置 The real-time reflection of the Page 2 current mode is already "nmi processing mode". 设 Figure 4-2 Changes to the csr register when entering/exiting nmi ### 4.4. Exit nmi processing mode When the program finishes nmi processing, it finally needs to exit from the nmi server and return to the main program. Since the NMI processing is in Machine Mode, the software must use the mret instruction when exiting the NMI. The hardware behavior of the processor after executing the mret Page 28 # instruction is as follows. Note that the following hardware behavior is done simultaneously in one clock cycle: - The execution of the current program flow is stopped and the execution begins with the PC address defined by the CSR register mepc. - Update the CSR register mstatus. - Update Privilege Mode and Machine Sub-Mode. The overall process of exiting nmi is as follows Figure 4-3 Figure 4-3 所示。 设置 Figure 4-3 Exiting the overall process of nmi These will be detailed below. ### 4.4.1. Execute from the PC address defined by mepc Upon entering the NMI, the mepc register is updated simultaneously to reflect the PC value of the next instruction that encountered the NMI at that time. Through this mechanism, it means that after the execution of the mret instruction, the processor returns to the PC address of the next instruction that encountered the NMI at that time, so that the program stream that was previously aborted can be executed. ### 4.4.2. Update the CSR register mstatus The detailed format of the mstatus register is shown in Table 7-2, Table 7-2. After executing the mret instruction, the hardware will automatically update the CSR. ## Register mstatus some fields: - The value of the mstatus. MIE field is restored to the value of the current mstatus. MPIE. - The value of the mstatus. MPIE field is updated to 1. - The updated values of the mstatus. MPP domain are divided into the following two cases: - When user mode U-mode is configured, mstatus. MPP is updated to 0x0. • When user mode U-mode is not configured, mstatus. MPP is updated to 0x11. Upon entering the NMI, the value of mstatus. MPIE was updated to the mstatus, MIE value before the NMT occurred. After the mret instruction executed, the value mstatus. MIE is restored to the value of mstatus. MPIE, such as Figure 4-2 Figure 4-2Shown. Through this mechanism, it that after the mret means instruction is executed, the processor's mstatus. MIE value is restored to the value before the NMI occurred (assuming the previous mstatus. MIE value is 1, it means that the interrupt is re-opened globally). ### 4.4.3. Update Privilege Mode When entering the NMI, the value of mstatus. MPP was updated to the Privilege Mode before the NMI occurred, while it was executing. After the mret instruction, the processor's Privilege Mode is restored to the value of mstatus. MPP, such as Figure 4-2 Figure 4-2 Shown. This mechanism ensures that the processor returns to the Privilege Mode of the processor before the NMI occurred. ### 4.4.4. Update Machine Sub-Mode The Machine Sub-Mode of the Bumblebee kernel is reflected in real time in the msubm. TYP field of the CSR register. Executing After the mret instruction, the hardware will automatically restore the processor's Machine Sub-Mode to the value of the msubm. PTYP field: ■ When entering the NMI, the value of the msubm. PTYP field was updated to the Machine Sub-Mode before the NMI occurred. value. After exiting the NMI with the mret instruction, the hardware restores the value of the processor Machine Sub-Mode to The value of the msubm. PTYP field, such as Figure 4-2 Figure 4-2 Shown. This mechanism means that after exiting the NMI, the processor's Machine Sub-Mode is restored to the Machine Sub-Mode before the NMI occurred. 4.5. Nmi service program When the processor enters the NMI, it begins to execute the new program from the PC address defined by the mnvec register, which is usually Nmi service program. Note: Since there is no hardware to automatically save and restore the context in the nmi and exit nmi mechanisms, the software needs to explicitly use the instructions (written in assembly language) for context saving and recovery. Please combine a complete mcu chip The nmi server code example understands it. ### 4.6. Nmi/abnormal nesting The Bumblebee kernel is customized like Figure 4-4 Figure 4-4 Two Levels of NMI/Exception State Save Stacks, which can save up to three levels of NMI/Exception processor state, can achieve secondary recoverable NMI/Exception nesting. Note: Because the NMI's response is masked on the hardware when the processor is in the NMI state, the NMI cannot self-nesert. The Nmir/Exception Nesting of the # Bumblebee kernel supports only the following three nestings: - Nmi nesting exception - Exception nesting exception - Abnormal nesting nmi ### **Entry:** Figure 4-4 Schematic diagram of the two-stage NMI/Exception state stack mechanism of the Bumblebee kernel ### 4.6.1. Enter nmi/exception nesting In response to NMI and exceptions, the hardware behavior of the Bumblebee kernel is as Figure 4-4 Figure 4-4 As shown, it can be # briefly described as follows. - Stop executing the current program flow and start executing from the new pc address. - If the response is an exception, it is executed from the PC address stored by mtvec. - If the response is MI, it starts from the PC address stored by mnvec. - Update the relevant csr registers, which are the following registers and their associated fields: - Mepc: Record the PC before the current NMI/exception, and recover the NMI/PC before the exception occurs from the mepc when exiting the NMI/Exception. - Msaveepc1: The first-level NMI/exception state stack records the PC before the first-level nested NMI/exception (NMI/Exception nested by the current NMI/Exception), that is, the mepc value before the current NMI/Exception occurs, and exits. The value of mepc can be recovered from msaveepc1 when NMI/Exception. - Msaveepc2: The second-level NMI/Exception State Stack records the second-level nested NMI/Exception (is nested by the first level NMI/Exception Nested NMI/Exception) The PC before the occurrence, that is, the current NMI/msaveepc1 before the occurrence of the abnormality The value of msaveepc1 can be recovered from msaveepc2 when exiting NMI/Exception. mstatus: - ◆ Mpie: Record the current mie before the nmi/abnormal occurrence. - ◆ MPP: Record the Privilege Mode before the current NMI/Exception occurred. #### msavestatus: - ◆ Mpiel: The first-level nmi/abnormal state stack records the mie before the first-level nested nmi/abnormality, that is, the mpie before the current nmi/abnormality, and the value of mpie can be restored from mpiel when exiting the nmi/exception. - ◆ Mpie2: The second-level nmi/abnormal state stack records the mie before the second-level nested nmi/abnormality, that is, the mpil before the current nmi/exception occurs, and the value of mpie1 can be recovered from mpie2 when exiting nmi/anomaly. - ◆ MPP1: The first-level NMI/abnormal state stack records the first-level nested NMI/Privilege Mode before the occurrence of the exception, that is, the MPP before the current NMI/exception occurs, and can be recovered from the MPP1 when the NMI/Exception is exited. ### The value of mpp. ◆ MPP2: The second-level NMI/Exception State Stack records the second-level nested NMI/Privilege Mode before the occurrence of the exception, that is, the current NMI/MPP1 before the exception occurs, and the MMI2 can be recovered when the NMI/Exception is exited. ## The value of mpp1. - Mcause: Records the cause of the current NMI/Exception. - Msavecause1: The first-level NMI/Exception Status Stack records the first-level nested NMI/Exception Cause. - Msavecause2: The second-level NMI/Exception Status Stack records the second-level nested NMI/Exception Cause. ### msubm: - ◆ TYP: Records the current NMI/exception Trap type. - ◆ PTYP: records the type of trap that the processor is in before the current NMI/exception occurs. - ◆ PTYP1: The first-level NMI/abnormal state stack records the Machine Sub Mode before the first-level nested NMI/abnormality, that is, the current NMI/PTYP before the abnormality occurs. When the NMI/Exception is exited, the value of PTYP can be restored from PTYP1. - ◆ PTYP2: The second-level NMI/abnormal state stack records the second-level nested NMI/Machine Sub Mode before the exception occurs, that is, the current NMI/PTYP1 before the abnormality occurs, and the value of PTYP1 can be restored from the PTYP2 when the NMI/abnormal is exited. - NMI/Exception Handling is done in Machine Mode, so when entering NMI/Exception, the Privilege Mode of the processor core switches to Machine mode. ### 4.6.2. Exit nmi/exception nesting After the program completes the NMI/Exception handling, it finally needs to exit from the NMI/Exception Service program and return to the superior NMI/Exception or the main Before exiting, it program. necessary to restore the processor from the relevant registers. state This is done by the mret instruction, the processor executes. behavior after the hardware mret instruction is as followsFigure 4-4 Figure 4-4Can be briefly described as follows. - The execution of the current program flow is stopped and the execution begins with the PC address defined by the CSR register mepc. - Update the relevant csr registers, which are the following registers and their associated fields: - Mepc (Machine Exception Program Counter): Reverts to the PC stored in the first level of nested NMI/Exception in msaveepc1. - Msaveepc1: first-level NMI/exception state stack, mret occurs from secondlevel NMI/exception state stack Msaveepc2 restores the register msaveepc1 value, which is restored to the second level of nesting stored in msaveepc2 ## Nm / pc before the occurrence of an abnormality. - mstatus (Machine Status Register) - ◆ Mpie: Reverts to mie before the first-level nested nmi/exception stored in mpiel. - ◆ MPP: Reverts to the first level of nested NMI/Privilege Mode before the exception occurred in MPP1. #### msavestatus: ◆ MPIE1: First level NMI/Exception state stack, mret occurs from second level NMI/Exception state stack MPIE2 restores the value of the register field msavestatus. MPIE1, which is restored to the MIE before the second-level nested NMI/exception stored in MPIE2. ◆ MPP1: first-level NMI/exception state stack, mret occurs from second-level NMI/exception state stack MPP2 restores the value of the register field msavestatus. MPP1, which is restored to the Privilege Mode before the second-level nested NMI/exception stored in MPP2. Mcause (Machine Cause Register): Revert to the first level of nesting stored in msavecause1 The cause of nmi/abnormality. Msavecause1: first-level NMI/exception state stack, mret occurs from second-level NMI/exception state stack Msavecause2 restores the value of register msavecause1, which is the reason for reverting to the second-level nested ## NMI/exception stored in msavecause2. - msubm (Machine Sub-Mode Register) - ◆ TYP: Reverts to the Trap type of the processor before the current NMI/Exception occurred in msubm. PTYP. - ◆ PTYP: Revert to the first-level nested NMI/Exception occurrence preprocessor stored in msubm. PTYP1 ### Trap type. ◆ PTYP1: First level NMI/Exception Status Stack, mret occurs from the second level NMI/Exception Status Stack The value of the PTYP2 recovery register field msubm. PTYP1 is restored to the Trap type of the second-level nested NMI/pre-existing processor stored in msubm. PTYP2. #### 5. Bumblebee kernel interrupt mechanism introduction #### 5.1. Interrupt overview Interrupt mechanism, that is, the processor core is suddenly interrupted by other requests during the execution of the program instruction flow, and the execution of the current program aborted, and then other things are processed, after waiting for other things to be processed, and then Go back to the point where the program was interrupted before continuing to execute the previous program instruction stream. Some basic points of knowledge of the ### interruption are as follows: - The "other request" interrupted by the processor is called the Interrupt Request. The source of the "other request" is called the interrupt source. The interrupt source usually comes from outside the kernel. It can also be internal to the core (becoming an internal interrupt source). - The "other thing" that the processor goes to handle is called the Interrupt Service Routine (ISR). - Interrupt processing is a normal mechanism, not an error situation. After the processor receives the interrupt request, it needs to save the scene of the current program, which is referred to as "save site". After processing the interrupt service routine, the processor needs to restore the previous site, thereby continuing to execute the previously interrupted program, referred to as "recovery site." - There may be multiple interrupt sources that simultaneously initiate requests to the processor, and these interrupt sources need to be arbitrated to select which interrupt source is prioritized. This situation is called "interrupt arbitration", and different interrupts can be assigned levels and priorities to facilitate arbitration, so there is a concept of "interrupt level" and "interrupt priority". #### **5.2.** Interrupt controller eclic As described in Section 7.4.13, the Bumblebee kernel supports "default interrupt mode" and "ECLIC interrupt mode" through different configurations of the software. It is recommended to use "ECLIC interrupt mode". This article only introduces "ECLIC interrupt mode". The Bumblebee kernel implements an "Improved Core Local Interrupt (Enhanced Core Local Interrupt) Controller, ECLIC) can be used to manage multiple interrupt sources. All types of interrupts in the Bumblebee kernel (except for debug interrupts) are managed by ECLIC. For details on ECLIC, see Section 6.2. About Bumblebee Kernel See Section 5.3 for an introduction to all supported interrupt types. #### **5.3.** Interrupt type The types of interrupts supported by the Bumblebee kernel are as Figure 5-1 Figure 5-1 Schematic diagram of the interrupt type These will be detailed below. #### 5.3.1. External Interrupt An external interrupt is an interrupt from outside the processor core. External interrupts allow users to connect to external interrupt sources, such as external devices Interrupts generated by uart, gpio, etc Note: The Bumblebee core supports multiple external interrupt sources, all of which are managed by ECLIC. #### 5.3.2. Internal interrupt The Bumblebee kernel has several kernel-specific internal interrupts, namely: - Software Interrupt - Timer Interrupt Note: The internal interrupts of the Bumblebee kernel are also managed by ECLIC. age 30 #### **5.3.2.1** The main points of the software interrupt software interruption are as #### follows: - The Bumblebee kernel implements a TIMER unit, and a msip register is defined in the TIMER unit to generate software interrupts. See Section 6.1.6 for details. - Note: Software interrupts are also managed by eclic. #### **5.3.2.2** The main points of the timer interrupt timer interrupt are as #### follows: - The Bumblebee kernel implements a TIMER unit, and a timer is defined in the TIMER unit to generate a timer interrupt. See Section 6.1.5 for details. - Note: Timer interrupts are also managed by eclic. #### **5.3.2.3** Memory access error interrupt # The main points of the "memory access error exception" conversion are as follows: When the Bumblebee kernel encounters a "memory access error exception", it does not generate an exception, but - **5.4.** Interrupt mask - 5.4.1. Interrupt global mask The Bumblebee kernel interrupt can be masked, and the MIE field of the CSR register mstatus controls the global enable of the interrupt. See Section 7.4.8 for details. 5.4.2. Interrupt source separately shielded For different interrupt sources, eclic assigns its own interrupt enable register to each interrupt source. The user can configure the eclic registers to manage the masking of each interrupt source. See Section 6.2.6 for details. Page 37 5.5. Interrupt level, priority and arbitration When multiple interrupts occur at 需要响应时 tingsarbitration is the same required. For the Bumblebee core processor, ECLIC manages all interrupts in a unified manner. ECLIC assigns its own interrupt level and priority register to each interrupt source, which can be configured by the user. The eclic register manages the level and priority of each interrupt source. When multiple interrupts occur simultaneously, eclic arbitrates the level. And the highest priority interrupt, such as Figure 5-2 Figure 5-2 Shown in . See Section 6.2.9 for details. Figure 5-2 Schematic diagram of interrupt arbitration 5.6. Enter interrupt processing mode The hardware behavior of the Bumblebee kernel can be briefly described as follows in response to an interrupt. Note that the following ## hardware behavior is done simultaneously in one clock cycle: ■ Stop executing the current program flow and start executing from the new pc address. - Page 38 - In addition to this, entering the interrupt also updates the Privilege Mode of the processor core and the Machine Sub-Mode. - The overall processFigure 5-3 Figure 5-3 Shown in . Figure 5-3 Overall response to the interrupt These will be detailed below. #### **5.6.1.** Execute from the new pc address Each interrupt source of ECLIC can be set to vector or non-vector processing (via the shv field of the register clicintattr[i]). The main points are as follows: If configured as a vector processing mode, after the interrupt is responded by the processor core, the processor jumps directly into the target address stored in the vector table entry of the interrupt. For a detailed description of the interrupt vector table, see Section 5.8. For a detailed description of the vector processing mode, see Section 5.13.2. If configured as a non-vector processing mode, the processor jumps directly into the interrupt after the interrupt is processed by the processor core. Page 39 Interrupt the shared entry address. For a detailed description of the interrupt non-vector processing mode, see Section 5.13.1. #### 5.6.2. Update Privilege Mode Upon entering the interrupt, the processor kernel's Privilege Mode is updated to Machine Mode. #### 5.6.3. Update Machine Sub-Mode The Machine Sub-Mode of the Bumblebee kernel is reflected in real time in the msubm. TYP field of the CSR register. Upon entering the interrupt, the Machine Sub-Mode of the processor core is updated to the interrupt handling mode, so: The value of the msubm. PTYP field of the CSR register is updated to the Machine Sub-Mode (msubm. TYP field before the interrupt occurs). The value), as shown in Figure 5-4 Figure 5-4. The role of the msubm. PTYP field is to be able to use after the end of the interrupt. ing The value of msubm. PTYP recovers the Machine Sub-Mode value before the interrupt occurred. The value of the msubm. TYP field of the CSR register is updated to "interrupt processing mode", as shown in Figure 5-4 Figure 5-4. Setting The current mode is already Set reflected in the "interrupt processing mode". ng #### 5.6.4. Update CSR register mepc return address of the The Bumblebee kernel exit interrupt is specified by the CSR register mepc. Upon entering the interrupt, hardware will automatically update the value of the register, which will be used as the return address of the exit interrupt. After the interrupt is completed, it can use its saved PC value to return ## to the program point that was previously stopped. #### note: - When an interrupt occurs, the interrupt return address mepc is pointed to an instruction that failed to complete execution due to the occurrence of the interrupt. Then, after exiting the interrupt, the program will return to the previous program point and re-execute from the unexecuted instruction stored by mepc. - Although the mepc register is automatically updated by hardware when an interrupt occurs, the mepc register itself is a readable and writable register, so software can also write to it directly to modify its value. - 5.6.5. Update the CSR registers meause and mstatus The detailed format of the mcause register is shown in Table 7-6, Table 7-6. CFF hosting when the Bumblebee kernel enters the interrupt ing Set Settin The mcause is updated simultaneously (hardware automatically), such as Figure 5-4 Figure 5-4 As shown, the details Page 43 Page 40 ### are as follows: - After the current interrupt is responded, a mechanism is needed to record the current id number of the interrupt source. - When the Bumblebee core enters the interrupt, the CSR register mcause. EXCCODE field is updated to reflect the ID number of the ECLIC interrupt source for the current response, so the software can read the register to query the specific ID of the interrupt source. - The current interrupt is responded, possibly interrupting the interrupt that was previously being processed (the interrupt level is relatively low, so it can be interrupted), and a mechanism is needed to record the Interrupt Levels of the interrupted interrupt. - When the Bumblebee core enters the interrupt, the CSR register meause. MPIL field is updated to reflect the interrupted interrupt level (the value of the mintstatus. MIL field). The purpose of the meause. MPIL field is to use the value of meause. MPIL to recover the mintstatus. MIL value before the interrupt occurred after the end of the interrupt. - After the current interrupt is responded, a mechanism is needed to record the interrupt global enable state and privileged mode before responding to the interrupt. - When the Bumblebee core enters the interrupt, the value of the mstatus. MPIE field in the CSR register is updated to the global enable state of the interrupt before the interrupt occurred (the value of the mstatus. MIE field). The value of the mstatus. MIE field is updated to 0. (It means that the interrupt is globally closed after entering the interrupt service routine, all interrupts will be masked and not ### responding). - When the Bumblebee kernel enters the interrupt, the processor's current privilege mode (Privilege Mode) switches to Machine Mode, and the value of the CSR register mstatus. MPP field is updated to the Privilege Mode before the interrupt occurs. - If the interrupt of the current response is in vector processing mode, the processor will jump directly into the target address stored in the vector table entry of the interrupt after responding to the interrupt. For a detailed description of the interrupt vector processing mode, see Section 5.13.2. In terms of hardware implementation, the processor needs to be divided into two steps. The first step is to take the stored target address from the interrupt vector table, and then jump to the target address in the second step. Then, in the first step of the memory access operation of "removing the stored target address from the interrupt vector table", a memory access error may occur, and a mechanism is needed to record such a special memory access error. - When the Bumblebee core enters an interrupt, if the interrupt is in vector processing mode, the CSR register The value of the mcause minhy field is updated to 1 until the "two-step" operation described above is completely successful. The value of the mcause.minhv field is cleared to 0. Assuming a memory access error occurs midway, the final processor will have an Instruction access fault and the mcause.minhv field has a value of 1 (not cleared). Note: The values of the instatus MPIE and instatus MPP fields are mirrored with the values of the incause MPIE and incause MPP fields, ie, under normal circumstances, the value of the instatus MPIE field and the value of the incause MPIE field are always Is completely one As such, the value of the mstatus. MPP field is always exactly the same as the value of the mcause. MPP field. Figure 5-4 Changes to the csr register when entering/exiting an interrupt #### 5.7. Exit interrupt processing mode After the program completes the interrupt processing, it finally needs to exit from the interrupt service routine and return to the main program. Since the interrupt processing is in Machine Mode, the instruction when exiting the interrupt. The hardware behavior of the processor after executing the mret instruction is as follows. Note that the following hardware behavior is done simultaneously in one clock cycle: - The execution of the current program flow is stopped and the execution begins with the PC address defined by the CSR register mepc. - Executing the mret instruction will not only cause the processor to jump to the above PC address to start execution, but also let the hardware update several other CSR registers at the same time, such as Figure 5-4 Figure 5-4 As shown, they are the following registers: - mstatus (Machine Status Register) - mcause (Machine Cause Register) - mintstatus (Machine Interrupt Status Register) - In addition to this, entering the interrupt also updates the Privilege Mode of the processor core and the Machine Sub-Mode. Figure 5-5 Overall process of exiting the interrupt ### These will be detailed below. #### 5.7.1. Execute from the PC address defined by mepc Upon entering the interrupt, the mepc register is updated simultaneously to reflect the PC value at the time the interrupt was encountered. The software must exit the interrupt using the mret instruction. After executing the mret instruction, the processor will resume execution from the pc address defined by mepc. Through this mechanism, it means that after the execution of the mret instruction, the processor returns to the PC address when the interrupt was encountered, so that the program stream that was previously aborted can be executed. 5.7.2. Update the CSR registers meause and mstatus The detailed format of the mcause register is shown in Table 7-6, Table 7-6. After executing the mret instruction, the hardware will automatically update some fields of the CSR register meause: - Upon entering the interrupt, the value of mcause. MPIL was updated to the mintstatus. MIL value before the interrupt occurred. After exiting the interrupt with the mret instruction, the hardware restores the value of mintstatus. MIL to the value of mcause. MPIL. Through this mechanism, it means that after the exit interrupt, the processor's mintstatus. MIL value is restored to the value before the interrupt occurred. - Upon entering the interrupt, the value of mcause. MPIE was updated to the mstatus. MIE value before the interrupt occurred. And use After the mret instruction exits the interrupt, the hardware will restore the mstatus. MIE value to mcause. MPIE after executing the mret instruction Value, such as Figure 5-4 Figure 5-4 Shown. Through this mechanism, it means that after the interrupt is interrupted ## the processor's mstatus.MIE ## The value is restored to the value before the interrupt occurred. Upon entering the interrupt, the value of meause. MPP was updated to the Privilege Mode before the interrupt occurred. After exiting the interrupt with the mret instruction, the hardware restores the processor privilege mode (Privilege Mode) to The value of mcause. MPP, such as Figure 5-4 Figure 5-4 Shown. Through this mechanism, it means that after the exit interrupt, the processor's privilege mode (Privilege Mode) is restored to the mode before the interrupt occurred. Note: The values of the mstatus. MPIE and mstatus. MPP fields are mirrored with the values of the mcause. MPIE and mcause. MPP fields, ie, under normal circumstances, the value of the mstatus. MPIE field and the value of the mcause. MPIE field are always It is exactly the same, the value of the field is always exactly the same as the value of the mcause.MPP field After executing the mret instruction, the hardware will automatically update the processor's Privilege Mode to the value of the mcause. MPP field: ■ Upon entering the interrupt, the value of meause. MPP was updated to the Privilege Mode before the interrupt occurred. After exiting the interrupt with the mret instruction, the hardware restores the processor privilege mode (Privilege Mode) to The value of mcause. MPP. Through this mechanism, it means that after the exit interrupt, the processor's privilege mode (Privilege Mode) is restored to the mode before the interrupt occurred. #### 5.7.4. Update Machine Sub-Mode The Machine Sub-Mode of the Bumblebee kernel is reflected in real time regita the msubm. TYP field of the CSR register. Executing After the mret instruction, the hardware will automatically restore the processor's Machine Sub-Mode to the value of the msubm. PTYP field: When an interrupt is entered, the value of the msubm. PTYP field is updated to the Machine Sub-Mode value before the interrupt occurred. After exiting the interrupt with the mret instruction, the hardware restores the value of the processor Machine Sub-Mode to The value of the msubm. PTYP field, such as Figure 5-4 Figure 5-4 Shown. This mechanism means that after the exit interrupt, the processor's Machine Sub-Mode is restored to the Machine Sub-Mode before the interrupt occurred. #### 5.8. Interrupt vector table Such as Figure 5-6 Figure 5-6 As shown in the figure, the interrupt vector table refers to a continuous address space opened in the memory, the address ing Each word of the space (Word) is used to store the Interrupt Service Routine corresponding to each interrupt source of the ECLIC (Interrupt Service Routine, Se tting Isr) The pc address of the function. The start address of the interrupt vector table is specified by the CSR register mtvt. The mtvt register can usually be set to the beginning of the entire code segment. The role of the interrupt vector table is very important. When the processor responds to an interrupt source, whether the interrupt is in vector processing mode or non-vector processing mode, the hardware will eventually jump to the corresponding address by querying the pc address stored in the interrupt vector table. In the interrupt service routine function, see Section 5.13 for more details. Figure 5-6 Schematic diagram of the interrupt vector table 5.9. Context save and restore of incoming and outgoing interrupts The risc-v architecture processor does have hardware not automatically save and restore context (general purpose registers) operations when entering and exiting the interrupt processing mode, software is required to explicitly (in assembly language) use instructions for context saving and recovery. Depending on whether the interrupt is in vector processing mode or non-vector processing mode, content involved in context the saving and recovery will vary, see First 5.13 Learn more about the section. **5.10.** Interrupt response delay The concept of interrupt response delay usually refers to instruction consumed from "external interrupt source pull-up" to "the first instruction in the Interrupt Service Routine (ISR) that the processor actually starts executing the interrupt source". The number of cycles. Therefore, the interrupt response delay usually includes the ## periodic overhead of the following aspects: - The overhead of the processor core to jump after responding to the interrupt - The cycle overhead spent by the processor core to save the context - The overhead that the processor core jumps into the Interrupt Service Routine (ISR). The interrupt response delay will vary depending on whether the interrupt is in vector processing mode or non-vector processing mode, see section **5.13** Learn more about the section. #### **5.11.** Interrupt nesting While the processor core is processing an interrupt, there may be a new interrupt request of a higher level. The processor can abort the current interrupt service routine and start responding to the interrupt and execute "interrupt service routine". So, the interrupt nesting is formed (that is, previous interrupt has the responded yet, and the new interrupt is started again), and the nested hierarchy can have many layers. ## Take Figure 5-7 Figure 5-7 An example of this is: Setting Settin Assuming the processor is processing a timer interrupt and suddenly another button 1 interrupt is coming (level is higher than the timer interrupt), the processor will pause processing the timer interrupt and begin processing the button 1 interrupt. ■ But suddenly another button 2 interrupt comes (level is higher than button 1 interrupt), then the processor will pause ## When the button 1 is interrupted, the button 2 interrupt is processed. - After that, no other higher-level interrupts will come, the button 2 interrupt will not be interrupted, the processor can successfully complete the interrupt of the button 2, and then return to the button 1 interrupt handler, complete the button 1 interrupt Processing. - After completing the processing of the button 1 interrupt, the processor will return to the timer interrupt handler to complete the timer interrupt processing. Figure 5-7 Schematic diagram of interrupt nesting Note: Assuming that the new interrupt request has a lower priority (or the same) as the interrupt level being processed, the processor should not respond to this new interrupt request. The processor must complete the current interrupt service routine before considering the new response. Interrupt request (since the level of the new interrupt request is not higher than the interrupt level currently being processed). See Section 6.2.9 for more information on interrupt level settings. In the Bumblebee kernel, depending on whether the interrupt is in vector processing mode or non-vector processing mode, the support method for interrupt nesting will vary, see section **5.13** Learn more about the section. #### 5.12. Interrupted biting While the processor core processing an interrupt, a new interrupt request may be coming, but the "new interrupt level" is lower than or equal to "the interrupt level currently being processed", so the new interrupt cannot interrupt the current interrupt. Interrupt (so does not form a nest). After the processor completes the current interrupt, it is theoretically necessary to restore the context, then exit the interrupt back to the main application, then re-respond to the new interrupt, and in response to the new interrupt, the be saved context needs to again. Therefore, there is a back-toback "recovery context" and "save context" operation. If this back-toback "recovery context" and "save context" are omitted, it is called "medium". Broken tail bite, such as Figure 5-8 Figure 5-8 As shown, it is obvious that interrupting the tail bite can speed up the back-to-back processing speed of multiple interruptions. Settin Settin Corresponding interrupt handler. By biting the tail, it saves the processing time of one recovery and save site. Figure 5-8 Schematic diagram of interrupt bite In the Bumblebee kernel, interrupt biting is only supported in non-vector processing mode, see Section 5.13.1.3 for more details. **5.13.** Interrupted vector processing mode and non-vector processing mode As described in Section 6.2.2062.10, each interrupt source of eclic can be set to vector or non-vector processing (by sending ing The shv domain of the memory clicintattr[i], the vector processing mode and the non-vector processing mode have large differences, respectively, as follows. - 5.13.1. Non-vector processing mode - 5.13.1.1 Features and delays of non-vector processing modes If configured as a non-vector processing mode, the interrupt is interrupted by the processor core and the processor jumps directly into the ## entry address of all non-vector interrupt shares. The entry address can be set by software: ■ If the least significant bit of the configuration CSR register mtvt2 is 0 (power—on reset default), the entry address of all non-vector interrupt shares is specified by the value of the CSR register mtvec (ignoring the value of the lowest 2 bits). Since the value of the mtvec register also specifies the entry address of the exception, it means that in this case, the exception and all non-vector interrupts share the entry point. #### site. ■ If the least significant bit of the configuration CSR register mtvt2 is 1, then the entry address shared by all non-vector interrupts is specified by the value of the CSR register mtvt2 (ignoring the value of the lowest 2 bits). In order for the interrupt to be responded and processed as fast as possible, it is recommended to set the least significant bit of the CSR register mtvt2 to 1, ie, specify a separate entry address for all non-vector interrupts by mtvt2, and the exception entry address (by The value of mtvec is specified) completely separated. # After entering the entry address of all non-vector interrupt shares, the processor will begin executing a common piece of software code, such as Figure 5-9 Figure 5-9 In the example shown, the contents of this software code are usually as follows - First save the CSR registers mepc, meause, msubm into the stack. These CSR registers are saved to ensure that subsequent interrupt nesting is functional, because the new interrupt response will overwrite the values of mepc, meause, and msubm, so they need to be saved to the stack first. - Save several general-purpose registers (the context of the processor) onto the stack. - Then execute a special instruction "csrrw ra, CSR\_JALMNXTI, ra". If there is no interruption waiting #### (Pending), the instruction is equivalent to a Nop instruction does nothing; if there is an interrupt waiting (Pending), after executing the instruction, the processor will: - The target address stored in the Vector Table Entry of the interrupt is directly jumped into the Interrupt Service Routine (ISR) of the interrupt source. - While jumping into the interrupt service routine, the hardware also turns on the global enable of the interrupt, that is, sets the MIE field of the mstatus register to 1. After the interrupt global enable is enabled, the new interrupt can be responded to achieve the effect of interrupt nesting. - The "csrrw ra, CSR\_JALMNXTI, ra" command also reaches JAL while jumping into the interrupt service routine. (Jump and Link) effect, the hardware also updates the value of the Link register as the return address of the PC itself of the instruction as a function call. Therefore, after returning from the interrupt service routine function, it will return to the "csrrw ra, CSR JALMNXTI, ra" instruction to re-execute, and re-determine whether there is still an interrupt waiting (Pending), thereby achieving the effect of interrupting the tail bite. • At the end of the interrupt service routine, you also need to add the corresponding recovery context pop operation. And before the CSR registers mepc, meause, msubm are out of the stack, the global enable of the interrupt needs to be turned off again to ensure the mepc, The atomicity of meause, msubm recovery operations (not needs to be turned off again to ensure the mepc, The atomicity of meause, msubm recovery operations (not needs to be turned off again to ensure the mepc, The atomicity of meause, msubm recovery operations (not needs to be turned off again to ensure the mepc, The atomicity of meause, msubm recovery operations interrupts). Figure 5-9 Example of interrupted non-vector processing mode (always nesting is always supported) Since the processor needs to execute a common software code for context preservation before jumping to the interrupt service routine in the non-vector processing mode, the first instruction in the interrupt service routine is executed from the interrupt source to the processor. Need to experience the following clock cycle overhead: - The overhead of the processor core responding to a jump after an interrupt. Ideally about 4 clock cycles. - The processor core saves the overhead of the CSR registers mepc, meause, and msubm into the stack. - The periodic cost of the processor core saving the context. If it is the architecture of rv32e, you need to save 8 general-purpose registers. If it is the architecture of rv32i, you need to save 16 general-purpose registers. - The overhead that the processor core jumps into the Interrupt Service Routine (ISR). Ideally, it takes about 5 clock cycles. ## Interrupt nesting in non-vector processing mode As mentioned above, non-vector processing mode can always support interrupt nesting, such as Figure 5- 10 Figure 5-10 The example shown in the example: Assume that the three interrupt sources 30, 31, 32 come in succession, and "level of interrupt source 32" > "level of interrupt source 31" > "level of interrupt source 30", then later Interrupts interrupt interrupts that were previously processed to form interrupt nesting. Figure 5-10 Three successive (non-vector processing mode) interrupts form a nest For non-vector processing mode interrupts, the "interruption bite" saves significant time (saving one back—to—back save context) since the processor has to save and restore the context before jumping into and out of the interrupt service routine. And recovery context). As mentioned above, in all common code segments shared by non-vector interrupts, the "csrrw ra, CSR\_JALMNXTI, ra" instruction also achieves the effect of JAL (Jump and Link) while jumping into the interrupt service routine, and the hardware is updated simultaneously. The value of the Link register is the return address of the PC itself of the instruction as a function call. Therefore, after returning from the interrupt service routine function, it will return to the "csrrw ra, CSR\_JALMNXTI, ra" instruction to reexecute, and re-determine whether there is still an interrupt waiting (Pending), thereby achieving the effect of interrupting the tail bite. Such as Figure 5-11 Figure 5-11 Example shown in the following: Assume that the three interrupt sources 30, 29, and 28 come succession, and "level of interrupt source 30" >= "level of interrupt source 29" >= "level of interrupt 28", then Subsequent source interrupts will not interrupt the interrupt that was being processed before (no interrupt nesting will be formed), but will be placed in the Pending state. When the interrupt #### source 30 is completed After processing, interrupt processing of interrupt source 29 will be started directly, eliminating the intermediate "recovery context" and "save context" procedures. Figure 5-11 Schematic diagram of interrupt bite #### 5.13.2. Vector processing mode 5.13.2.1 The characteristics and delay of the vector processing mode If configured as a vector processing mode, after the interrupt is responded by the processor core, the processor directly jumps to the target address stored in the Vector Table Entry of the interrupt, that is, the interrupt service routine of the interrupt source (Interrupt Service) Routine 5-ISR), such as Figure 5-12 The example shown in . Figure 5-12 Example of vector processing mode for interrupts ## The vector processing mode has the following characteristics: - In the vector processing mode, the processor jumps directly to the interrupt service routine and does not save the context. Therefore, the interrupt response delay is very short, from the interrupt source to the first instruction in the interrupt service routine. Basically, only hardware is required to perform table lookup and jump time overhead, ideally about 6 clock cycles. - For vector service mode interrupt service routine functions, special interrupt ((interrupt)) must be used to modify the interrupt service routine function. - In the vector processing mode, since the processor does not save the context before jumping into the interrupt service routine, the interrupt service routine function itself cannot theoretically call the subfunction (ie, must be a Leaf Function). - If the interrupt service routine function accidentally calls another subfunction (not a Leaf Function), it will cause a function error if it is not processed. In order to avoid this accidental error situation, as long as a special Attribute ((interrupt)) to modify the interrupt service program function, then compiler will automatically determine, when the compiler finds that the function calls other sub-functions, it will automatically insert a piece of for code context preservation. Note: In this case, although the correctness of the function is guaranteed, overhead caused by saving the context will actually increase response delay of the the interrupt (equivalent to non-vector mode) and cause the expansion of the code size. . Therefore, in practice, if the vector processing mode is used, it is not recommended to call other sub-functions in the vector processing mode interrupt service routine #### function. In the vector processing mode, the processor does not perform any special processing before jumping into the interrupt service routine, and since the processor core responds to the interrupt, the MIE field in the mstatus register will be automatically updated by the hardware. (meaning that the interrupt globally closed and respond to new interrupts). Therefore, the vector processing mode does not support interrupt nesting default. In order to achieve the processing mode vector and interrupt the nesting effect, such asFigure 5-13 Figure 5-13 As shown in the figure, you need to add a special push operation at the beginning of the interrupt service routine: • First save the CSR registers mepc, meause, msubm into the stack. These CSR registers are saved to ensure that subsequent interrupt nesting functions correctly, because the new interrupt response will overwrite mepc, meause, ### The value of msubm, so you need to save them to the stack first. - Re-enable the global enable of the interrupt, that is, set the MIE field of the mstatus register to 1. After the interrupt global enable is enabled, the new interrupt can be responded to achieve the effect of interrupt nesting. - At the end of the interrupt service routine, you also need to add the corresponding recovery context pop operation. And before the CSR registers mepc, meause, msubm are out of the stack, the global enable of the interrupt needs to be turned off again to ensure the mepc, The atomicity of mcause, msubmrecovery operations (not interrupted by new interrupts). Figure 5-13 Example of vector processing mode for interrupts (support interrupt nesting) #### **5.13.2.2** Vector processing mode interrupt nesting As mentioned above, interrupts in vector processing mode can also support interrupt nesting after special processing, such as Figure 5-14 Figure 5-14 The example shown in the example: Assume that the three interrupt sources 30, 31, 32 come in succession, and "level of interrupt source 32" > "level of interrupt source 31" > "level of interrupt source 30", then later Interrupts interrupt interrupts that were previously processed to form interrupt nesting. Figure 5-14 Three successive (vector processing mode) interrupts form a nest #### 5.13.2.3 Vector processing mode interrupt bite ## For the vector processing mode interrupt, since the processor does not save the context before jumping into the interrupt service routine, the meaning of "interrupt biting" is not significant. Therefore, the vector processing mode is interrupted without "interruption". The ability to bite the tail. - 6. Introduction to Bumblebee Core TIMER and ECLIC - **6.1.** Timer introduction - 6.1.1. Introduction to timer Timer Unit (TIMER), which is mainly used to generate timer interrupts in the Bumblebee kernel (Timer Interrupt) and Software Interrupt. See Sections 5.3.2.1 and 5.3.2.2 for details on timer interrupts and software interrupts. **6.1.2.** Timer register ## Timer is a unit of memory address mapping: - The base address of the TIMER unit in the Bumblebee kernel is described in the Bumblebee Kernel Concise Data Sheet. - Timer unit address and address offsetTable 6-1 Table 6-1 Shown in . Table 6-1 Memory Map Addresses of the timer Register | Intra-module<br>offset address | Read and<br>write<br>properti | Register<br>name | Reset<br>default | Function<br>al<br>descript<br>ion | |--------------------------------|-------------------------------|------------------|------------------|-------------------------------------------------------------------------------------------------------------------------| | 0x0 | Readable<br>and<br>writable | mtime_lo | 0x00000000 | Reflects the lower 32-bit value of timer mtime, see section 6.1.3 Learn more about it in detail. | | 0x4 | Readable and writable | mtime_hi | 0x00000000 | Reflects the high 32-bit value of the timer mtime, see section 6.1.3 Learn more about it in detail. | | 0x8 | Readable<br>and<br>writable | mtimecmp_lo | 0xFFFFFFFF | Configure the timer comparison value mtimecmp to be lower 32 bits, see See section 6.1.5 Learn more about it in detail. | | 0xC | Readable<br>and<br>writable | mtimecmp_hi | 0xFFFFFFFF | Configure the timer comparison value mtimecmp high 32 bits, see See section 6.1.5 Learn more about it in detail. | | 0xFF8 | Readable<br>and<br>writable | mstop | 0x00000000 | Control the pause of the timer, see section 6.1.4 Learn about it in detail Detailed introduction. | | 0xFFC | Readable<br>and<br>writable | msip | 0x00000000 | Generate software interrupts, see section 6.1.6 Learn more about it Shao. | #### note: - TIMER's registers only support aligned read and write accesses with a size of (Size). - The register range of TIMER is 0x00 $^{\sim}$ 0xFF, and the value in the address other than the one listed in the above table is constant 0. The function and use of each register are described in detail below. ## 6.1.3. Timing through the mtime register # The timer can be used for real time timing. The main points are as follows - A 64-bit mtime register is implemented in TIMER, concatenated by {mtime\_hi, mtime\_lo}, which reflects the value of the 64-bit timer. The timer increments according to the low-speed input beat signal. The timer is turned on by default, so it will always count. - In the Bumblebee kernel, the self-incrementing frequency of this counter is controlled by the processor's input signal mtime\_toggle\_a, see the document Bumblebee Core Concise Data Sheet for details on this input signal. ## 6.1.4. Pause timer through mstop register Since the timer's timer is powered on, it will continue to increment by default, in order to turn off this timer in some special cases. Counting, an mstop register is implemented in TIMER. Such as Table 6-2 As shown, the mstop register As a valid bit, this valid bit acts directly as a timer's pause control signal, so software can set the mstop register 置 ## 1 to pause the timer. | | Table 6 2 bit fred of register mstop | | | | | | |------------|--------------------------------------|----------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|--|--| | doma<br>in | Bit | Attribut<br>es | Reset value | desc<br>ript | | | | name | | | | ion | | | | Reserved | 7:1 | Read only,<br>write ignore | N/A | Unused field, value is constant 0 | | | | TIMESTOP | | Readable and<br>writable | 0 | Control the timer to run or pause. If the value of this field is 1, the timer pauses counting. Otherwise normal auto increment. | | | Table 6-2 Bit field of register mstop ## 6.1.5. Generate timer interrupts via the mtime and mtimecmp registers # The timer can be used to generate a timer interrupt, the main points are as follows: A 64-bit mtimecmp register is implemented in TIMER, which is composed of age 59 {mtimecmp\_hi, mtimecmp\_lo}. This register is used as a comparison value of the timer, assuming that the value mtime of the timer is greater than or equal to The value of mtimecmp generates a timer interrupt. The software can clear the timer interrupt by overwriting the value of mtimecmp or mtime (so that mtimecmp is greater than the value of mtime). Note: The timer interrupt is connected to the eclic unit for unified management. For details on eclic, please refer to <u>6.26.2</u> Section. 6.1.6. Generate software interrupts via msip register TIMER can be used to generate software interrupts. A msip register is implemented in TIMER, such as Table 6-3 Table 6-3 As shown in the msip register, only the least significant bit is a valid bit, which is directly interrupted as a software, so: - Software write generates a software interrupt by writing a 1 to the msip register; - Software can clear the software interrupt by writing a 0 to the msip register. Note: Software interrupts are connected to the eclic unit for unified management. For details on eclic, see section **6.2** Section. doma Bit Attribut Reset value desc in ript es name ion Reserved 7:1Read only, N/A Unused field, value is write ignore constant 0 This field is used to generate MSIP Readable and writable software interrupts Table 6-3 Bit field of register msip ### 6.2. Eclic introduction The Bumblebee kernel supports "improved kernel interrupt controllers optimized from the RISC-V standard CLIC (Enhanced Core Local Interrupt Controller, ECLIC)", used to manage all interrupt sources. ## Note: - Eclic serves only one processor core and is private to the processor core. - The software programming model of eclic is also backward compatible with the standard clic. ### **6.2.1.** Introduction to eclic Eclic is used to arbitrate, send requests, and support interrupt nesting for multiple internal and external interrupt sources. Eclic register Such as Table 6-5 Table 6-5 Said logical structure such as Figure 6-1 Figure 6-1 As shown, the related concepts are as follows: - Eclic interrupt target - Eclic interrupt source - Eclic interrupt source number - Eclic register - Eclic interrupt source enable bit - Eclic interrupt source wait flag - Level or edge attribute of the eclic interrupt source - Eclic interrupt source level and priority color, color, - Vector or non-vector processing of eclic interrupt sources - Eclic interrupt target threshold level - Arclic interrupt arbitration mechanism - The response, nesting, and tailing mechanisms of the eclic interrupt are detailed below. ## 6.2.2. Eclic interrupt target Figure 6-2 eclic relationship structure diagram **6.2.3.** Eclic interrupt source # Such cas Figure: 6-21 Figure: 6-2 As shown, from the programming model. The programming model to wing each source interrupt source and parameters wing each - Number (id) - Enable bit (ie) - Waiting flag bit (ip) - Level or Edge-Triggered - Level and Priority - Vector or Non-Vector Mode is described below. ## **6.2.4.** Eclic interrupt source number (id) Eclic assigns a unique number (id) to each interrupt source. For example, if the hardware implementation of an eclic really supports 4096 ids, the id should be 0 to 4095 note: - In the Burblebee kernel, interrupts with interrupt ID numbers 0 through 18 are reserved as kernel-specific internal interrupts. - The interrupt source id assigned to the normal external interrupt starts at 19 and can # Detailed introduction <u>Table 6-4 Table</u> 6-4 Shown in . Table 6-4 eclic interrupt source number and assignment | Eclic interrupt<br>number | Feat<br>ures | Interrupt<br>source<br>introducti | | | |---------------------------|-----------------------|---------------------------------------------------------------------------|--|--| | | | on | | | | 0 | Reserved | The interrupt is not used by the Bumblebee kernel. | | | | 1 | Reserved | The interrupt is not used by the Bumblebee kernel. | | | | 2 | Reserved | The interrupt is not used by the Bumblebee kernel. | | | | 3 | Software interruption | A software interrupt generated by the TIMER unit of the Bumblebee kernel. | | | | 4 | Reserved | The interrupt is not used by the Bumblebee kernel. | | | | 5 | Reserved | The interrupt is not used by the Bumblebee kernel. | | | | 6 | Reserved | The interrupt is not used by the Bumblebee kernel. | | | | 7 | Timer interrupt | The timer generated by the TIMER unit of the Bumblebee kernel Broken. | | | | 8 | Reserved | The interrupt is not used by the Bumblebee kernel. | | | | 9 | Reserved | The interrupt is not used by the Bumblebee | |-----------|---------------------|------------------------------------------------| | | | kernel. | | 10 | Reserved | The interrupt is not used by the Bumblebee | | | | kernel. | | 11 | Reserved | The interrupt is not used by the Bumblebee | | | | kernel. | | 12 | Reserved | The interrupt is not used by the Bumblebee | | | | kernel. | | 13 | Reserved | The interrupt is not used by the Bumblebee | | | | kernel. | | 14 | Reserved | The interrupt is not used by the Bumblebee | | | | kernel. | | 15 | Reserved | The interrupt is not used by the Bumblebee | | | | kernel. | | 16 | Reserved | The interrupt is not used by the Bumblebee | | | | kernel. | | | Memory access error | Bumblebee kernel memory access error turned | | 17 | interrupt | into internal | | | | Interrupted. | | 18 | Reserved | The interrupt is not used by the Bumblebee | | 10 | neser ved | kernel. | | | External Interrupt | | | | DATOTIAL INTERITAPE | Normal external interrupts are available for | | | | user connections.note: | | 19 ~ 4095 | | Although ECLIC supports up to 4096 interrupt | | | | sources from the programming model, the actual | | | | number of interrupt sources supported by the | | | | hardware is reflected in the information | | | | register clicinfo. NUM INTERRUPT. | | | | TOSTBOOL CITCHING, NOW THINKING I. | ## 6.2.5. Eclic register ## Eclic is a unit of memory address mapping: - The base address of the ECLIC unit in the Bumblebee kernel is described in the Bumblebee Kernel Concise Data Sheet. - Register and address offsets in the eclic unitTable 6-5 Table 6-5 Shown in . Table 6-5 Intra-cell address offset of the eclic register | Attr | name | width | |----------|------|-------| | ihad | | | | <br>ibut | | | 设置 color, color, | | es | | | |------------|------------------|-------------|-------| | 0x0000 | Readable and | cliccfg | 8 | | | writable | | digit | | | | | S | | 0x0004 | Read only, write | clicinfo | 32 | | | ignore | | bit | | 0x000b | Readable and | mth | 8 | | | writable | | digit | | | | | S | | 0x1000+4*i | Readable and | clicintip[i | 8 | | | writable | ] | digit | | | | | S | | 0x1001+4*i | Readable and | clicintie[i | 8 | | | writable | ] | digit | | | | | S | | 0x1002+4*i | Readable and | clicintattr | 8 | | | writable | [i] | digit | | | | | S | | 0x1003+4*i | Readable and | clicintct1[ | 8 | | | writable | i] | digit | | | | | S | #### note: - The above i represents the ID number of the interrupt, and the register with the [i] suffix indicates that there is a separate register for each interrupt source. - ECLIC's registers support aligned read and write accesses of byte, half-word, or word. - Writes to the above "read only" registers are ignored, but no bus error exceptions are generated. The actual eclic may not be configured with 4096 interrupt sources, so the value of the corresponding register of the non-existing interrupt source is constant 0 The individual registers are described in detail below. 6.2.5.1 Register cliccfg The cliccfg register is a global configuration register. Software can rewrite this register to configure several global parameters. For details on the specific bit field, seeTable 6-6 Table 6-6 Shown in . Table 6-6 Bit field of register cliccfg | doma<br>in<br>name | Bit | Attribut<br>es | Reset<br>value | desc<br>ript<br>ion | | |--------------------|-----|----------------------------|----------------|--------------------------------------------|--| | Reserved | 7:5 | Read only,<br>write ignore | N/A | Unused field, value is constant 0 | | | nlbits | 4:1 | Readable and | 0 | Bit used to specify the Level field in the | | | | | writable | | clicintctl[i] register | | | | | | | Number, see section 6.2.9 Learn more about it in detail. | |----------|---|----------------------------|-----|----------------------------------------------------------| | Reserved | 0 | Read only,<br>write ignore | N/A | Unused field, value is constant 1 | ## 6.2.5.2 Register clicinfo The clicinfo register is a global information register that software can read to view several global parameters For details on the bit field, see <a href="#Table 6-7">Table 6-7</a> Shown in . doma Bit Attributes Reset desc value in ript ion 31:25 Read only, N/A Unused field, value is Reserved write ignore constant 0 CLICINTCTLBITS 24:21 N/A Read only, The number of bits used to write ignore specify the valid bits in the clicintctl[i] register, see section 6.2.9 Learn more about it in detail. VERSION 20:13 N/A Hardware implementation Read only, write ignore version number NUM INTERRUPT 12:0 Read only, N/A Number of interrupt sources write ignore supported by hardware Table 6-7 Bit field of register clicinfo ### 6.2.5.1 Register mth The mth register is the threshold level register of the interrupt target. Software can rewrite the register to configure the threshold level of the interrupt target. For details of the specific bit field, see Table 6-8 Table 6-8 Shown in . Table 6-8 Bit field of register mth | doma<br>in<br>name | Bit | Attribut<br>es | Reset<br>value | desc<br>ript<br>ion | |--------------------|-----|-----------------------|----------------|------------------------------------------------------------------------------| | mth | 7:0 | Readable and writable | N/A | Threshold level register for interrupt target, see section 6.2.11 Learn more | | | | | | about it<br>Shao. | 6.2.5.2 Register clicintip[i] The clicintip[i] register is the wait flag register of the interrupt source. For details of the specific bit field, seeTable 6-9 Table 6-9 Central 示。 Table 6-9 Bit field of register clicintip[i] | | | | | <u>-</u> | |--------------------|-----|----------------------------|----------------|--------------------------------------------------------------------------------------------| | doma<br>in<br>name | Bit | Attribut<br>es | Reset<br>value | desc<br>ript<br>ion | | Reserved | 7:1 | Read only,<br>write ignore | N/A | Unused field, value is constant 0 | | IP | 0 | Readable and<br>writable | 0 | Waiting flag bit of the interrupt source, see section 6.2.7 Learn more about it in detail. | 6.2.5.3 Register clicintie[i] The clicintie[i] register is the enable register of the interrupt source. For details of the specific bit field, see <u>Table 6-10 Table 6-10</u> Shown in . Table 6-10 Bit field of register clicintip[i] | doma<br>in<br>name | Bit | Attribut<br>es | Reset<br>value | desc<br>ript<br>ion | |--------------------|-----|----------------------------|----------------|------------------------------------------------------------------------------------------| | Reserved | 7:1 | Read only,<br>write ignore | N/A | Unused field, value is constant 0 | | IE | 0 | Readable and<br>writable | 0 | The enable bit of the interrupt source, see section 6.2.6 Learn more about it in detail. | ## **6.2.5.4** Register clicintattr[i] The clicintattr[i] register is the attribute register of the interrupt source. Software can rewrite several registers of the interrupt source by rewriting this register. Sex, see the specific bit field information. Table 6-11 Table 6-11 Shown in . Page 66 ## Table 6-11 Bit fields of the register clicintattr[i] | doma | Bit | Attribut | Reset value | desc | |------|-----|----------|-------------|------| | in | | es | | ript | | name | | | | ion | | Reserved | 7:6 | Read only,<br>write ignore | N/A | Unused field, value is constant 3 | |----------|-----|----------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------| | Reserved | 5:3 | Read only,<br>write ignore | N/A | Unused field, value is constant 0 | | trig | 2:1 | Readable and<br>writable | 0 | Specify the level or edge attribute of the interrupt source, See section 6.2.8 Learn more about it in detail. | | shv | 0 | Readable and<br>writable | 0 | Specify whether the interrupt source uses vector processing mode or non-vector processing mode, see section 6.2.10 Learn more about it in detail. | 6.2.5.5 Register clicintctl[i] The clicintctl[i] register is the control register for the interrupt source. Software can override this register to configure the level of the interrupt source. (Level) and Priority (Priority), the Level and Priority fields are dynamically allocated according to the value of cliccfg. nlbits, see section **6.2.9** Learn more about it in detail. Such as Figure 6-2 Figure 6-2 As shown, eclic assigns an interrupt enable bit (ie) to each interrupt source, reflected in the register. In clicintie[i]. IE, its functions are as follows: 置 - The clicintie[i] register of each interrupt source is a readable and writable register of the memory address map so that software can program it. - If the clicintie[i] register is programmed to 0, it means that this interrupt source is masked. - If the clicintie[i] register is programmed to be 1, it means that this interrupt source is turned on. - 6.2.7. Eclic interrupt source wait flag (ip) Such as Figure 6-2 Figure 6-2 As shown, eclic assigns an interrupt wait flag (ip) to each interrupt source, reflected in the registration. In clicintip[i]. IP, its function is as follows: 设 - If the ip bit of an interrupt source is high, it indicates that the interrupt source is triggered. The trigger condition of the interrupt source depends on whether it is a level-triggered or edge-triggered attribute, see section 6.2.8 Detailed introduction of the section. - The ip bit software of the interrupt source is readable and writable. The behavior of the software to write the ip bit depends on whether it is a level-triggered or edge-triggered attribute. 6.2.8 Detailed introduction of the section. - For edge-triggered interrupt sources, their ip may also have hardware self-clearing behavior, see section 6.2.8 Detailed introduction of the section. 6.2.8. Level or Edge-Triggered of the ECLIC interrupt source Such as Figure 6-2 Figure 6-2 As shown, each interrupt source of eclic can be set to level trigger or edge triggered attributes (through The trig field of the register clicintattr[i], the main points are as follows: 置 - When clicintattr[i]. trig[0] = 0, set the interrupt attribute to a level-triggered interrupt: - If the interrupt source is configured for level triggering, the ip bit of the interrupt source will reflect the level of the interrupt source in real time. - If the interrupt source is configured as a level trigger, since the ip bit of the interrupt source reflects the level value of the interrupt source in real time, the software write operation of the interrupt ip bit is ignored, that is, the software cannot be set by the write operation or Clear the value of the ip bit. If the software needs to clear the interrupt, it can only be done by clearing the final source of the interrupt. - When clicintattr[i]. trig[0] = 1 and clicintattr[i]. trig[1] = 0, set the interrupt attribute to a rising edge triggered interrupt: - If the interrupt source is configured as a rising edge trigger, when eclic detects the rising edge of the interrupt source, the interrupt source is triggered in eclic, and the ip bit of the interrupt source is set high. - If the interrupt source is configured for a rising edge trigger, software - writes to the interrupt ip bit, that is, the software can set or clear the value of the ip bit by a write operation. - Note: For the rising edge triggered interrupt, in order to improve the efficiency of interrupt processing, when the interrupt is responded and the processor core jumps into the Interrupt Service Routines (ISR), the ECLIC hardware will automatically clear the interrupt. The interrupted IP bit eliminates the need to software clear the IP bit of the interrupt within the ISR. - When clicintattr[i]. trig[0] = 1 and clicintattr[i]. trig[1] = 1, set the interrupt attribute to the interrupt triggered by the falling edge: - If the interrupt source is configured as a falling edge trigger, when eclic detects the falling edge of the interrupt source, the interrupt source is triggered in eclic and the ip bit of the interrupt source is set high. - If the interrupt source is configured as a falling edge trigger, the software write to the interrupt ip bit will take effect, ie, the software can set or clear the value of the ip bit by a write operation. - Note: For the interrupt triggered by the falling edge, in order to improve the efficiency of the interrupt processing, when the interrupt is responded and the processor core jumps into the Interrupt Service Routines (ISR), the ECLIC hardware will automatically clear the interrupt. The interrupted IP bit eliminates the need to software clear the IP bit of the interrupt within the ISR. ## 6.2.9. ECLIC interrupt source level and priority (Level and Priority) Such as Figure 6-2 Figure 6-2 As shown, each interrupt source of eclic can be set to a specific level and priority (via register Page 68 设置 ## Clicintctl[i]), the main points are as follows: ■ The clicintctl[i] register of each interrupt source is theoretically 8 bits wide, and the real number of bits that the hardware actually implements is The clicinfoCTLBITS field of the clicinfo register is specified. For example, if the value of clicinfo. CLICINTCTLBITS field is it means that only the upper bits of the clicintctl[i] register are true valid bits, lowest 2 and the bits are constant 1, such as Figure Figure 6-3 The example in example. • Note: The value of the clicintctlbits field is a read-only fixed constant that cannot be overwritten by software. The theoretically reasonable range is 2 <= clicintctlbits <= 8. The actual actual value is determined by the hardware implementation of the processor core. In the valid bit of the clicintctl[i] register, there are two dynamic fields, which are used to specify the level of the interrupt source. (Level) and Priority (Priority). The width of the Level field is specified by the nlbits field of the cliccfg register. For example, if the value of the cliccfg. nlbits field is 4, it means that the upper 4 bits of the valid bit of the clicintctl[i] register are the Level field, and the other lower significant bits are the Priority field, such as Figure 6-3 Figure 6-3 The example in the example. • Note: The value of the cliccfg.nlbits field is a readable and writable field that can be programmed by the software. clicintctl[i] #### Figure 6-3 Example format of the register clicintctl[i] - The main points related to the level of the interrupt source are as follows: - The digital values of Level are interpreted in a left-aligned manner, and the low bits except the effective bit width (specified by cliccfg.nlbits) are all filled with a constant constant of 1, such as Figure 6-4 Figure 6-4 The example in the example. - ◆ Note: If cliccfg.nlbits > clicinfo.CLICINTCTLBITS, it means that the number of bits indicated by nlbits exceeds the valid bit of the clicintctl[i] register, and the excess bits are all filled with the complement constant 1. - ◆ Note: If cliccfg.nlbits = 0, the numeric value of Level will be considered a fixed 255. Such as Figure 6-5 Figure 6-5 The example in the example. - The higher the numeric value of Level, the higher its level. Note: ◆ High-level interrupts can interrupt low-level interrupt processing, resulting in interrupt nesting, see Section 5.11 ## Detailed introduction of the section. ◆ Multiple interrupts are waiting at the same time (IP bit is high). ECLIC needs to arbitrate to determine which interrupt is sent to the kernel for processing. The arbitration needs to refer to the Level | #nlbits | 编码 | | | | Level的数 | 数字值 | | | | |---------|--------------------------------------|-------------|-------------|----------|-----------|-----------|-----------|----------|-------| | 1 | L | | | | 127, | | | | 255 | | 2 | (= L1111111)<br>LL | | 63, | | 127, | | 191, | | 255 | | 3 | (= LL111111)<br>LLL | 31, | 63, | 95, | 127, | 159, | 191, | 223, | 255 | | 4 | (= LLL11111)<br>LLLL<br>(= LLLL1111) | 15, 31, 47, | 63, 79, | 95, 111, | 127, 143, | 159, 175, | 191, 207, | 223, 239 | , 255 | | | 、<br>比特表示Level的<br>表示Level域之外 | | <b>,</b> 采用 | 月全部补 | 1的方式 | | | | | value of each interrupt source. See the detailed description in Section 5.5. Figure 6-4 How to interpret the digital value of Level | cliccfg设置的若干 | cliccfg设置的若干示例: | | | | | | |----------------|-----------------|---------------|-------------------------------------|--|--|--| | CLICINTCTLBITS | nlbits | clicintctl[i] | Level的数字值 | | | | | 0 | 2 | | 255 | | | | | 1 | 2 | L | 127, 255 | | | | | 2 | 2 | LL | 63, 127, 191, 255 | | | | | 3 | 3 | LLL | 31, 63, 95, 127, 159, 191, 223, 255 | | | | | 4 | 1 | LPPP | 127, 255 | | | | | | | | | | | | | | | | | | | | Figure 6-5 Several examples of cliccfg settings - The main points related to the priority of the interrupt source are as follows: - The digital value of Priority is also interpreted in a left-aligned manner, effective bit width The lower bits except (clicinfo. CLICINTCTLBITS cliccfg. nlbits) are all filled with the complement constant 1. • The higher the numeric value of Priority, the higher its priority. Note: ◆ The priority of the interrupt does not participate in the judgment of interrupt nesting, that is, whether the interrupt can be nested and interrupted. The value of (Priority) does not matter, but is related to the value of the level of the interrupt level. ◆ When multiple interrupts are simultaneously Pending, ECLIC needs to arbitrate to determine which interrupt is sent to the core for processing. The arbitration needs to refer to the Priority digital value of each interrupt source. See section 6.2.12 Detailed introduction of the section. 6.2.10. Vector or Non-Vector Mode of ECLIC Interrupt Sources Each interrupt source of ECLIC can be set to vector or non-vector processing (via the shv field of the register clicintattr[i]). The main points are as follows: - If configured as a vector processing mode, after the interrupt is responded by the processor core, the processor jumps directly into the target address stored in the vector table entry of the interrupt. For a detailed description of the interrupt vector processing mode, see Section 5.13. - If configured to be a non-vector processing mode, then after the interrupt is responded by the processor core, the processor jumps directly into the entry address of all interrupt shares. For a detailed description of the interrupt non-vector processing mode, see Section 5.13. **6.2.11.** Eclic interrupt target threshold level # Such as Figure 6 Et Figure 6-1 As shown as Figure 6 to Figure 6 to Shown as Figure 6 to 7 Fi color, co1 The mth register is a complete 8-bit register, all bits are readable and writable, software can write this register configuration Target threshold. Note: This threshold characterizes a level value. or, The "level value" of the interrupt that ECLIC finally arbitrates is only higher than the value in the "mth register", and the interrupt can be sent to the processor core. **6.2.12.** Arclic interrupt arbitration mechanism ## Such as Figure 6-2. Figure 6-2. As shown, follows: color, • Only sources of interruption that meet all of the following conditions can participate in arbitration: color, - The enable bit of the interrupt source (clicintie[i] register) must be 1. - The wait flag bit (clicintip[i] register) of the interrupt source must be 1. - The rules for arbitration from all sources of interruption involved in arbitration are: - First, determine the level (Level), the larger the level value of the interrupt source, the higher the arbitration priority. - If the Levels are equal, then the Priority is determined. The larger the Priority number, the higher the arbitration priority. - If both Level and Priority are equal, the judgment interrupt ID is judged again, and the interrupt source with the larger interrupt ID has higher arbitration priority. - If the level value of the interrupt source that was last arbitrated is higher than the threshold level (mth) of the interrupt target, a final interrupt request is generated, pulling the interrupt request signal to the processor core high. 6.2.13. Eclic interrupt response, nesting, tail biting mechanism After the eclic interrupt request is sent to the processor core, the processor core will respond to it. Through eclic and kernel collaboration, you can support interrupt nesting, fast tail biting and other mechanisms. See Section 5.6, Section 5.11, Section 5.12 for details. - 7. Bumblebee kernel CSR register introduction - 7.1. Bumblebee Core CSR Register Overview Some control and status registers (CSRs) are defined in the RISC-V architecture to configure or log the status of some operations. The CSR register is a register internal to processor core and uses the proprietary 12-bit address encoding space. 7.2. Bumblebee kernel CSR register list A list of CSR registers supported by the Bumblebee kernel, such as Table 7-1 Table 7-1 As shown, including the crisr of the risc-v standard # Register (RV32IMAC architecture supports Machine Mode and User Mode related) and Bumblebee kernel custom expansion 世 The csr register of the show. Table 7-1 List of CSR Registers Supported by the Bumblebee Kernel | Type<br>s of | Csr<br>address | Read and<br>write<br>propertie | name | Full<br>name | |------------------------|----------------|--------------------------------|-----------|-------------------------------------------------------------------------------------------| | Risc-v standard<br>csr | 0xF11 | S<br>MRO | mvendorid | Commercial Supplier Number Register<br>(Machine<br>Vendor ID Register) | | (Machine | 0xF12 | MRO | marchid | Architecture Number Register (Machine Architecture | | Mode) | 0xF13 | MRO | mimpid | ID Register) Hardware Implementation Number Register (Machine Implementation ID Register) | | | 0xF14 | MRO | mhartid | Hart number register (Hart ID Register) | | | 0x300 | MRW | mstatus | Exception handling status register | | | 0x301 | MRO | misa | Instruction Set Architecture Register (Machine ISA) Register) | | | 0x304 | MRW | mie | Local interrupt mask control register (Machine Interrupt Enable Register) | | | 0x305 | MRW | mtvec | Exception entry base address register | | | 0x307 | MRW | mtvt | The base address of the eclic interrupt vector table | | | 0x340 | MRW | mscratch | Temporary register (Machine Scratch Register) | | | 0x341 | MRW | mepc | Machine Exception Program Counter | | | 0x342 | MRW | mcause | Abnormal Cause Register (Machine<br>Cause<br>Register) | | | 0x343 | MRW | mtval | Outlier register (Machine Trap<br>Value)<br>Register) | | Interrupt Pending Register) Pending Register National Temperature Pending Register Regis | | 0x344 | MRW | mip | Interrupt wait register (Machine | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------|-----|--------------|--------------------------------------| | Dx345 MRW mmxti | | | | | = ' | | Dx346 | | | | | | | Dx346 MRO mintstatus Standard return the handler entry address of the next interrupt vaddress values vaddress of the next interrupt values valu | | 0x345 | MRW | mnxti | | | Break and return the handler entry address of the next interrupt | | | | | | | Address of the next interrupt | | | | | next one | | 0x346 MRO mintstatus Standard register is used to save the current interrupt level 0x348 MRW mscratchcsw Standard registers are used to exchange when privileged mode changes Mscratch and destination register values 0x349 MRW mscratchcswl Standard registers are used to exchange when the interrupt level changes Mscratch and destination register values 0x800 MRW mcycle Lower 32 bits of Cycle counter 0x880 MRW mcycleh The upper 32 bits of the cycle counter (Upper 32 bits of Cycle counter 0x802 MRW minstret Complete the lower 32 bits of the instruction counter (Lower 32 bits of Instructions retired counter) 0x882 MRW minstreth Complete the 32 bits of Instructions retired counter 0x882 MRW minstreth Complete the 32 bits of Instructions retired counter 0x600 URO Cycle Read-only copy of the mcycle register x Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29.4 biderstanding 0x601 URO time Read-only copy of the minter register Note: Is this register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29.Festival Explain its details. 0x602 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29.Festival Explain its Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled value Note | | | | | Break and return the handler entry | | the current interrupt level 0x348 MRW mscratchcsw Standard registers are used to exchange when privileged mode changes Mscratch and destination register values 0x349 MRW mscratchcswl Standard registers are used to exchange when the interrupt level changes Mscratch and destination register values 0xB00 MRW mcycle Lower 32 bits of Cycle counter 0xB80 MRW mcycleh The upper 32 bits of the cycle counter (Upper 32 bits of the cycle counter (Upper 32 bits of the cycle counter (Upper 32 bits of frequency of the cycle counter) 0xB02 MRW minstret Complete the lower 32 bits of frequency of the instruction counter (Lower 32 bits of Instructions; retired counter) 0xB82 MRW minstreth Complete the 32 bits of Instructions; retired counter 0xB82 MRW minstreth Complete the 32 bits of Instructions; retired counter register Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29.4.190 therefore in User Mode? 0xC01 URO time Read-only copy of the mime register Note: Is this register readable by the TWR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29.1.39.Festival Explain its details. 0xC02 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29.4.190 therefore 7.4.297.4.29 | | | | | address of the next interrupt | | 0x348 | | 0x346 | MRO | mintstatus | Standard register is used to save | | exchange when privileged mode changes Mscratch and destination register values 0x349 MRW mscratchcswl Standard registers are used to exchange when the interrupt level changes Mscratch and destination register values 0xB00 MRW mcycle Lower 32 bits of Cycle counter 0xB00 MRW mcycleh The upper 32 bits of the cycle counter (Upper 32 bits of Cycle counter) 0xB02 MRW minstret Complete the lower 32 bits of the instruction counter (Llower 32 bits of Instructions retired counter) 0xB02 MRW minstret Complete the 32 bits of Instructions retired counter) 0xB02 MRW minstreth Complete the 32 bits of Instructions retired counter Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29.1.496 standing Details. 0xC01 URO time Read-only copy of the mtime register Note: Is this register readable by the TMR register readable by the TMR register mcounteren in User Mode? 0xC02 URO instret Read-only copy of the minstret register Mode? 8xed-only copy of the mtime register Note: Is this register readable by the TMR register mcounteren in User Mode? 8xed-only copy of the minstret register | | | | | the current interrupt level | | changes Mscratch and destination register values 0x349 MRW mscratchcswl Standard registers are used to exchange when the interrupt level changes Mscratch and destination register values 0xB00 MRW mcycle Lower 32 bits of Cycle counter 0xB80 MRW mcycle Lower 32 bits of the cycle counter (Upper 32 bits of Cycle counter) 0xB02 MRW minstret Complete the lower 32 bits of the instruction counter (Lower 32 bits of Instructions retired counter) 0xB82 MRW minstreth Complete the 32 bits of Instructions retired counter Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29 Index standing Details. 0xC01 URO time Read-only copy of the mtime register Note: Whether this register readable by the TMR register mounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. 0xC02 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. | | 0x348 | MRW | mscratchcsw | Standard registers are used to | | Mscratch and destination register values 0x349 MRW mscratchcswl Standard registers are used to exchange when the interrupt level changes Mscratch and destination register values 0xB00 MRW mcycle Lower 32 bits of Cycle counter 0xB00 MRW mcycleh The upper 32 bits of the cycle counter (Upper 32 bits of Cycle counter) 0xB02 MRW minstret Complete the lower 32 bits of the instruction counter (Lower 32 bits of Instructions retired counter) 0xB02 MRW minstreth Complete the 32 bits of Instructions retired counter 0xC00 URO cycle Read-only copy of the mcycle register Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding Details. 0xC01 URO time Read-only copy of the mtime register Note: Is this register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. 0xC02 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Hoderstanding Details in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Hoderstanding Details in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Hoderstanding Details in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Hoderstanding | | | | | exchange when privileged mode | | values values Standard registers are used to exchange when the interrupt level changes Mscratch and destination register values | | | | | changes | | Name | | | | | Mscratch and destination register | | exchange when the interrupt level changes Mscratch and destination register values 0xB00 MRW mcycle Lower 32 bits of Cycle counter 0xB80 MRW mcycleh The upper 32 bits of the cycle counter (Upper 32 bits of Cycle counter) 0xB02 MRW minstret Complete the lower 32 bits of the instruction counter (Lower 32 bits of Instructions_retired counter) 0xB82 MRW minstreth Complete the 32 bits of Instructions_retired counter Csr (User Mode) 0xC00 URO cycle Read-only copy of the mcycle register Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29_Understanding Details. 0xC01 URO time Read-only copy of the mtime register Note: Is this register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29_Festival Explain its details. 0xC02 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29_Understanding Details. | | | | | | | changes Mscratch and destination register values 0xB00 MRW mcycle Lower 32 bits of Cycle counter 0xB80 MRW mcycleh The upper 32 bits of the cycle counter (Upper 32 bits of Cycle counter) 0xB02 MRW minstret Complete the lower 32 bits of the instruction counter (Lower 32 bits of Instructions_retired counter) 0xB82 MRW minstreth Complete the 32 bits of Instructions_retired counter) 0xC00 URO cycle Read-only copy of the mcycle register Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29_Understanding Details. 0xC01 URO time Read-only copy of the miner register Note: Is this register readable by the TMR register readable by the TMR register readable by the TMR register redable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29_Festival Explain its details. 0xC02 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29_Understanding Details. | | 0x349 | MRW | mscratchcswl | Standard registers are used to | | changes Mscratch and destination register values 0xB00 MRW mcycle Lower 32 bits of Cycle counter 0xB80 MRW mcycleh The upper 32 bits of the cycle counter (Upper 32 bits of Cycle counter) 0xB02 MRW minstret Complete the lower 32 bits of the instruction counter (Lower 32 bits of Instructions_retired counter) 0xB82 MRW minstreth Complete the 32 bits of Instructions_retired counter) 0xC00 URO cycle Read-only copy of the mcycle register Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29_Understanding Details. 0xC01 URO time Read-only copy of the miner register Note: Is this register readable by the TMR register readable by the TMR register readable by the TMR register redable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29_Festival Explain its details. 0xC02 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29_Understanding Details. | | | | | exchange when the interrupt level | | Name | | | | | | | Name | | | | | Mscratch and destination register | | OxB00 MRW mcycleh The upper 32 bits of the cycle counter (Upper 32 bits of Cycle counter) OxB02 MRW minstret Complete the lower 32 bits of the instruction counter (Lower 32 bits of Instructions, retired counter) OxB02 MRW minstreth Complete the 32 bits of Instructions, retired counter OxC00 URO cycle Read-only copy of the mcycle register Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding Details. OxC01 URO time Read-only copy of the mtime register Note: Is this register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. OxC02 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding nearly copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding nearly copy of the minstret register mcounteren, see section 7.4.297.4.29 Understanding nearly copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | | | | | | Counter (Upper 32 dits of Cycle counter) | | 0xB00 | MRW | mcycle | Lower 32 bits of Cycle counter | | OxB02 MRW minstret Complete the lower 32 bits of the instruction counter (Lower 32 bits of Instructions_retired counter) OxB82 MRW minstreth Complete the 32 bits of Instructions_retired counter OxC00 URO cycle Read-only copy of the mcycle register Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding Details. OxC01 URO time Read-only copy of the mtime register Note: Is this register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. OxC02 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | 0xB80 | MRW | mcycleh | | | OxB02 MRW minstret Complete the lower 32 bits of the instruction counter (Lower 32 bits of Instructions_retired counter) OxB82 MRW minstreth Complete the 32 bits of Instructions_retired counter OxC00 URO cycle Read-only copy of the mcycle register Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding Details. OxC01 URO time Read-only copy of the mtime register Note: Is this register readable by the TMR register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. OxC02 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | | | | counter (Upper 32 bits of | | instruction counter (Lower 32 bits of Instructions_retired counter) OxB82 MRW minstreth Complete the 32 bits of Instructions_retired counter OxC00 URO cycle Read-only copy of the mcycle register Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding Details. OxC01 URO time Read-only copy of the mtime register Note: Is this register readable by the TMR register readable by the TMR register readable by the TMR register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. OxC02 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | | | | Cycle counter) | | bits of Instructions_retired counter) 0xB82 MRW minstreth Complete the 32 bits of Instructions-retired counter 0xC00 URO cycle Read-only copy of the mcycle register Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding Details. 0xC01 URO time Read-only copy of the mtime register Note: Is this register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. 0xC02 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | 0xB02 | MRW | minstret | Complete the lower 32 bits of the | | OxB82 MRW minstreth Complete the 32 bits of Instructions-retired counter OxC00 URO cycle Read-only copy of the mcycle register Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding Details. OxC01 URO time Read-only copy of the mtime register Note: Is this register readable by the TMR register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. OxC02 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the TR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | | | | instruction counter (Lower 32 | | OxB82 MRW minstreth Complete the 32 bits of Instructions-retired counter Risc-v standard csr (User Mode) URO cycle Read-only copy of the mcycle register Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding Details. OxC01 URO time Read-only copy of the mtime register Note: Is this register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. OxC02 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | | | | bits of Instructions-retired | | Risc-v standard csr (User Mode) URO URO Cycle Read-only copy of the mcycle register Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding Details. OxCO1 URO URO time Read-only copy of the mtime register Note: Is this register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. OxCO2 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | | | | | | Risc-v standard csr (User Mode) URO Cycle Read-only copy of the mcycle register Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding Details. OxCO1 URO time Read-only copy of the mtime register Note: Is this register readable by the TMR register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. OxCO2 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | 0xB82 | MRW | minstreth | | | Risc-v standard csr (User Mode) Tegister Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding Details. OxCO1 | | | | | Instructions-retired counter | | Note: Whether this register is readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.294.4.29 Understanding Details. OxCO1 URO time Read-only copy of the mtime register Note: Is this register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. OxCO2 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | 0xC00 | URO | cycle | Read-only copy of the mcycle | | readable in User Mode is controlled by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29 Under standing Details. OxCO1 URO time Read-only copy of the mtime register Note: Is this register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. OxCO2 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | Risc-v standard | | | | | | by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding Details. OxCO1 URO time Read-only copy of the mtime register Note: Is this register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. OxCO2 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | csr | | | | Note: Whether this register is | | by the CY bit field of the CSR register mcounteren, see section 7.4.297.4.29-Understanding Details. OxCO1 URO time Read-only copy of the mtime register Note: Is this register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29-Festival Explain its details. OxCO2 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29-Understanding | (Ugor Modo) | | | | readable in User Mode is controlled | | 7.4.297.4.29 Understanding Details. OxCO1 URO time Read-only copy of the mtime register Note: Is this register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. OxCO2 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | (User Mode) | | | | by the CY bit field of the CSR | | Details. OxCO1 URO time Read-only copy of the mtime register Note: Is this register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. OxCO2 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | | | | register mcounteren, see section | | OxCO1 URO time Read-only copy of the mtime register Note: Is this register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. OxCO2 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | | | | 7.4.297.4.29 Understanding | | Note: Is this register readable by the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. OxCO2 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | | | | Details. | | the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. 0xC02 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | 0xC01 | URO | time | Read-only copy of the mtime register | | the TMR register mcounteren in User Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. 0xC02 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | | | | Note: Is this register readable by | | Mode? Special domain to control, see section 7.4.297.4.29 Festival Explain its details. OxCO2 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | | | | | | Special domain to control, see section 7.4.297.4.29 Festival Explain its details. OxCO2 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | | | | _ | | section 7.4.297.4.29 Festival Explain its details. 0xC02 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | | | | | | Explain its details. OxCO2 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | | | | | | 0xC02 URO instret Read-only copy of the minstret register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | | | | | | register Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | | | | details. | | Note: Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | 0xC02 | URO | instret | | | readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | | | | | | by the IR bit field of the CSR register mcounteren, see section 7.4.297.4.29 Understanding | | | | | <u> </u> | | register mcounteren, see section 7.4.297.4.29 Understanding | | | | | | | 7. 4. 29 7. 4. 29 Understanding | | | | | by the IR bit field of the CSR | | | | | | | , | | | | | | | 7.4.297.4.29 Understanding | | Details. | | | | | Details. | 设置 设置 设1 设置 设置 设置 | 0x7d0 | MRW | mmisc_ctl | Custom registers are used to control the handler of nmi Entry address | |-------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0x7d6 | MRW | msavestatus | Custom registers are used to hold mstatus values | | 0x7d7 | MRW | msaveepc1 | Custom registers are used to save<br>the first level nested nmi<br>Or abnormal mepc | | 0x7d8 | MRW | msavecause1 | Custom registers are used to save<br>the first level nested nmi<br>Or unusual mcause | | 0x7d9 | MRW | msaveepc2 | Custom registers are used to hold<br>the second level nested nmi<br>Or abnormal mepc | | 0x7da | MRW | msavecause2 | Custom registers are used to hold the second level nested nmi Or unusual mcause | | 0x7eb | MRW | pushmsubm | Custom registers are used to store<br>the value of msubm in the heap<br>Stack address space | | 0x7ec | MRW | mtvt2 | Custom registers are used to set<br>non-vector interrupt handling<br>Mode interrupt entry address | | 0x7ed | MRW | jalmnxti | The custom register is used to enable the ECLIC interrupt. The read operation of this register can process the next interrupt and return the entry address of the next interrupt handler. Jump to this address. | | 0x7ee | MRW | pushmcause | Custom registers are used to store<br>the value of meause in the stack<br>address space | | 0x7ef | MRW | pushmepc | Custom registers are used to store<br>the value of mepc on the stack<br>Address space | | 0x811 | MRW | sleepvalue | Wfi sleep mode register | | 0x812 | MRW | txevt | Send Event Register | | 0x810 | MRW | wfe | Wait for Event Control Register | note: - MRW means Machine Mode Readable/Writeable - MRO stands for Machine Mode Read-Only - URW means User Mode Readable/Writeable - URO stands for User Mode Read-Only # 7.3. Access to the Bumblebee kernel's CSR register # The Bumblebee kernel has access to the CSR registers as follows: - Whether in Machine Mode or User Mode: - If you read or write to a non-existing CSR register address range, an Illegal Instruction is generated. Exce ptio n. - In Machine Mode: - Reading and writing to the csr register of the mrw or urw attribute is fine. - Reading the csr register of the mro or uro attribute is fine. - If you write to the CSR register of the MRO or URO attribute, an Illegal Instruction is generated. # Exception. - In User Mode: - Reading and writing the csr register of the urw attribute is fine. - Reading the csr register of the uro attribute is fine. - ◆ Note: For the cycle, cycleh, time, timeh, instret, and intreth registers of the URO attribute, its readability is also controlled by the relevant bit field of mcounteren, see 7.4.29 Learn more about it. - If you write to the CSR register of the URO attribute, an Illegal Instruction Exception is generated. - If you read or write to the CSR register of the MRW or MRO attribute, an Illegal Instruction Exception is generated. - **7.4.** RISC-V standard CSR supported by the Bumblebee kernel This section describes the Bumblebee kernel-defined CSR registers (the RV32IMAC architecture supports Machine Mode and User). Mode related). #### 7.4.1. misa The misa register is used to indicate the architectural characteristics supported by the current processor. The highest two bits of the misa register are used to indicate the number of architecture bits supported by the current processor: - If the highest two-bit value is 1, it means that it is currently a 32-bit architecture (rv32). - If the highest two-bit value is 2, it means that the current 64-bit architecture (rv64). - If the highest two-bit value is 3, it means that the current 128-bit architecture (rv128). The lower 26 bits of the misa register are used to indicate a subset of different modular instructions in the RISC-V ISA supported by the current processor, each | Bit | Character | Description | |-----|--------------|---------------------------------------------------------------------| | 0 | A | Atomic extension | | 1 | В | Tentatively reserved for Bit operations extension | | 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 | Tentatively reserved for Dynamically Translated Languages extension | | 10 | K | Reserved | | 11 | L | Tentatively reserved for Decimal Floating-Point extension | | 12 | M | Integer Multiply/Divide extension | | 13 | N | User-level interrupts supported | | 14 | O | Reserved | | 15 | P | Tentatively reserved for Packed-SIMD extension | | 16 | Q | Quad-precision floating-point extension | | 17 | $\mathbf{R}$ | Reserved | | 18 | S | Supervisor mode implemented | | 19 | T | Tentatively reserved for Transactional Memory extension | | 20 | U | User mode implemented | | 21 | V | Tentatively reserved for Vector extension | | 22 | W | Reserved | | 23 | X | Non-standard extensions present | | 24 | Y | Reserved | | 25 | Z | Reserved | A representation of a modular instruction set such as Figure 7-1 Figure 7-1 Shown in . The other unused bit fields of this register are constant 0. Figure 7--1 A subset of the modular instructions represented by the lower 26 bits of the misa register Note: The misa register is defined as a readable and writable register in the RISC-V architecture document, allowing some processors to be designed to dynamically configure certain features. However, in the implementation of the Bumblebee kernel, the misa register is a readonly register that constantly reflects the ISA modular subset supported by different processor cores. 7.4.2. mie The control bit of the mie register in ECLIC interrupt mode does not work, and reads mie returns all 0s. 7.4.3. mvendorid This register is a read-only register that reflects the commercial vendor number (Vendor ID) of the processor core. If the value of this register is 0, this register is not implemented. ## 7.4.4. marchid This register is a read-only register that reflects the hardware implementation microarchitecture ID of the processor core. If the value of this register is 0, this register is not implemented. ### 7. 4. 5. mimpid This register is a read-only register that reflects the hardware implementation number (Implementation ID) of the processor core. If the value of this register is 0, this register is not implemented. #### 7.4.6. mhartid This register is a read-only register that reflects the current Hart number (Hart ID). Hart (meaning "Hardware Thread") means a hardware thread. Multiple hardware threads may be implemented in a single processor core, such as hardware hyper-threading technology. Each set of threads has its own independent register group and other context resources. However, most of the computing resources are multiplexed by all hardware threads, so the area efficiency is high. In such a hardware hyper-threading processor, there are multiple hardware threads (Hart) in one core. The Hart number value in the Bumblebee kernel is controlled by the input signal core\_mhartid.Note: The RISC-V architecture stipulates that if there is at least one Hart number in the single Hart or multi-Hart system, it must be 0. #### 7. 4. 7. mstatus The mstatus register is the status register in Machine Mode. Each control bit field in the mstatus register Table 7-2 Table 7-2 Shown. Table 7-2 Control bits of the mstatus register | area | Bit | Reset<br>value | desc<br>ript<br>ion | |----------|-------|----------------|-----------------------------------------------------------------------------| | Reserved | 2:0 | N/A | Unused field is constant 0 | | MIE | 3 | 0 | See section 7.4.8 Festival to learn more about it | | Reserved | 6:4 | N/A | Unused field is constant 0 | | MPIE | 7 | 0 | See section 7.4.97.4.9 Festival to learn more about it | | Reserved | 10:8 | N/A | Unused field is constant 0 | | MPP | 12:11 | 0 | See section 7.4.97.4.9 Festival to learn more about it | | FS | 14:13 | 0 | See section <u>7.4.10</u> <del>7.4.10</del> Festival to learn more about it | | XS | 16:15 | 0 | See section 7.4.117.4.11 Festival to learn more | #### 7.4.8. MIE domain of mstatus The MIE field in the mstatus register indicates global interrupt enable: When the value of the mie field is 1, it indicates that the global switch of the interrupt is open, and the interrupt can be responded normally. When the value of the mie field is 0, it indicates that the interrupt is globally closed, the interrupt is masked, and the response cannot be responded. Note: When the Bumblebee core enters an exception, interrupt, or NMI processing mode, the value of the MIE is updated to 0 (meaning Page 79) that the interrupt is masked after entering an exception, interrupt, or NMI processing mode). #### 7.4.9. MPIE and MPP domains for mstatus The MPIE and MPP fields in the mstatus register are used to automatically save entry exceptions, before NMI and interrupts. Automatic recovery when mstatus. MIE and privileged mode (Privilege Mode). Update the hardware behavior of the mstatus registers MPIE and MPP fields when the Bumblebee kernel enters an exception, see 3.4.5 Learn more about it. When the Bumblebee kernel exits the exception (execute the mret instruction in exception handling mode), the mstatus register MPIE is updated. For hardware behavior of the mpp domain see Section 3.5.2 for details. Update the hardware behavior of the mstatus registers MPIE and MPP fields when the Bumblebee kernel enters the NMI, see 4.3.4 Learn more about it. When the Bumblebee kernel exits the NMI (execute the mret instruction in exception handling mode), the mstatus register MPIE is updated. For hardware behavior of the mpp domain see Section 4.4.2 for details. Update the hardware behavior of the mstatus register MPIE and MPP fields when the Bumblebee kernel enters the interrupt, see 5.6.5 Learn more about it. When the Bumblebee kernel exits the interrupt (execute the mret instruction in exception handling mode), the mstatus register MPIE is updated. For hardware behavior of the mpp domain see Section 5.7.2 for details. Note: The values of the mstatus. MPIE and mstatus. MPP fields are mirrored with the values of the mcause. MPIE and mcause. MPP fields, ie, under normal circumstances, the value of the mstatus. MPIE field and the value of the mcause. MPIE field are always Is exactly the same, The value of the mstatus. MPP field is always exactly the same as the value of the mcause. MPP field. #### 7.4.10. FS domain of mstatus The FS field in the mstatus register is used to maintain or reflect the state of the floating point unit. Note: This field will only exist if a floating point instruction (a subset of "f" or "d" instructions) is configured. The fs field consists of two bits, and its encoding is shown in the following figure. | Status | FS Meaning | XS Meaning | |--------|------------|------------------------------| | 0 | Off | All off | | 1 | Initial | None dirty or clean, some on | | 2 | Clean | None dirty, some clean | | 3 | Dirty | Some dirty | The update criteria for the fs domain are as follows: - The default value of FS after power-on is 0, which means that the state of the floating-point unit is Off. Therefore, in order to use the floating point unit normally, the software needs to use the CSR write instruction to rewrite the value of FS to a non-zero value to turn on the function of the floating point unit (FPU). - If the value of FS is 1 or 2, the value of FS is automatically switched to 3 after any floating-point instructions are executed, indicating that the state of the floating-point unit is Dirty (the state has changed). - If the processor does not want to use a floating-point unit (such as powering down the floating-point unit to save power), you can use the CSR write instruction to set the FS field of the mstatus register to 0 to turn off the function of the floating-point unit. Any operation that accesses the floating-point CSR register or any behavior that performs a floating-point instruction will cause an Illegal Instruction exception after the function of the floating-point unit is turned off. In addition to the above functions, the value of the fs field is also used for the guidance information of the operating system when performing context switching. For interested users, please refer to the original risc-v "privileged architecture document version 1.10". #### 7.4.11. XS domain of mstatus The XS field in the mstatus register is similar to the FS field, but it is used to maintain or reflect user-defined extended instruction unit status. The XS field is defined as a readonly field in the standard RISC-V "privileged architecture document version 1.10", which is used to reflect the state sum of all custom instruction units. Note, extended however, that in the hardware implementation of the Bumblebee kernel, the XS domain is designed to be a writable readable domain, which acts like a FS domain. Software can override the value of the XS field to the coprocessor extension turn instruction unit on or off. purpose. Similar to the fs domain, in addition to the above functions, xs is used for guidance information when the operating system performs context switching. For interested users, please refer to the risc-v "privileged architecture document version 1.10" original text. #### 7.4.12. SD domain of mstatus The SD field in the mstatus register is a read-only field that reflects the Dirty state of the XS or FS domain. Its logical relational expression is: SD = ((FS==11) OR (XS==11)). The reason for setting this readonly SD domain is to facilitate the software to quickly query whether the XS domain or the FS domain is in a Dirty state, so that it can quickly determine whether a floating-point unit or an extended instruction unit needs context for context switching. save. Interested users can refer to the original risc-v "privileged architecture document version 1.10". #### 7.4.13. mtvec The mtvec register is used to configure the entry address for interrupts and exception handlers. - The main points when mtvec configures the interrupted exception handler entry address are as follows: - The exception handler uses a 4byte aligned mtvec address (replace mtvec's lower 2bit with 0) as the entry address. - The main points when mtvec configures the entry address of the interrupt program are as follows: - When mtvec.MODE != 6'b000011, the processor uses the "default interrupt mode". - This mode is recommended when the processor uses "EQLIC Interrupt Mode" when mtvec.MODE = 6'b000011. - ◆ The entry address and key points when the interrupt is in non-vector processing mode 5.13.2 As stated in the section. - ◆ The entry address and points when the interrupt is in vector processing mode are as described in Section 5.13.1. Each address bit field of the mtvec registerTable 7-3 Table 7-3 Shown. Table 7-3 mtvec Register Control Bits | area | Bit | desc<br>ript<br>ion | |------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ADDR | 31:6 | Mtvec address | | MODE | 5: 0 | <ul> <li>The mode field is the interrupt handling mode control field:</li> <li>000011: eclic interrupt mode (recommended mode)</li> <li>Others: Default Interrupt Mode</li> </ul> | #### 7.4.14. mtvt The mtvt register is used to hold the base address of the ECLIC interrupt vector table, which is at least 64byte aligned. In order to improve the performance and reduce the number of hardware gates, the hardware determines the alignment of mtvt according to the number of interrupts actually implemented, such as <u>Table 7-4 Table 7-4</u> Shown. Table 7-4 mtvt alignment | Maximum<br>number of<br>interruption<br>s | Mtvt<br>alignment | |-------------------------------------------|-------------------| | 0 to 16 | 64-byte | | 17 to 32 | 128-byte | | 33 to 64 | 256-byte | | 65 to 128 | 512-byte | | 129 to 256 | 1KB | | 257 to 512 | 2KB | | 513 to 1024 | 4KB | | 1025 to 2048 | 8KB | | 2045 to 4096 | 16KB | 7.4.15. mscra tch The mscratch register is used by programs in Machine Mode to temporarily save certain data. The mscratch register provides a save and restore mechanism, such as temporarily storing the application's user stack pointer (SP) register in the mscratch register after entering the interrupt or exception handling mode, and then mscratch before exiting the exception handler. The value readout in the register is restored to the User Stack Pointer (SP) register. 7.4.16. mepc The mepc register is used to hold the PC value that the processor is executing before entering the exception, as the return address of the exception. To understand this register, see Chapter 3 for a systematic understanding of exceptions. ## note: - When the processor enters an exception, the mepc register is updated simultaneously to reflect the PC value of the instruction that is currently experiencing the exception. - It is worth noting that although the mepc register is automatically updated by hardware when an exception occurs, the mepc register itself is a readable and writable register (in Machine Mode), so the software can also write this register directly to modify its value. . Each address bit field of the mepc register Table 7-5 Table 7-5 Shown. Table 7-5 Control bits of the mepc register | area | Bit | desc<br>ript<br>ion | |----------|-----|----------------------------------------------------------------------------------------------------| | EPC | | Saves the pc value of the instruction that the processor is executing before the exception occurs. | | Reserved | 0 | Unused field is constant 0 | #### 7.4.17. mcause The mcause register is used to save the cause of the error before entering the NMI, exception, and interrupt, in order to diagnose and debug the cause of the trap. Each address field of the mcause register is Table 7-6 Table 7-6 Shown. Table 7-6 Control bits of the meause register | area | Bit | desc | |------|-----|------| | | | ript | | | | ion | | INTERRUPT | 31 | Indicates the current Trap type: | |-----------|----------------------------------|--------------------------------------------------------------| | | | ■ 0: abnormal or nmi | | | | 1: interrupt | | MINHV | 30 | Indicates that the processor is reading the interrupt vector | | | | table | | MPP | 29:28 | Enter the privileged mode before the interrupt, the same as | | | | mstatus.mpp | | MPIE | 27 | Interrupt before entering interrupt is enabled, same as | | | | mstatus.mpie | | Reserved | 26:24 | Unused field is constant 0 | | MPIL | 23:16 | Previous interrupt level | | Reserved | 15:12 Unused field is constant 0 | | | EXCCODE | 11:0 Exception/interrupt coding | | # note: - The MPIE and MPP fields of the mstatus register are mirrored to the MPIE and MPP fields of mcause. - NMI's mcause. EXCCODE may be 0x1 or 0xfff, and the actual value is controlled by mmisc\_ctl. For details, please refer to 7.5.4 Section. 7.4.18. mtval (mbadaddr) The mtval register (aka mbadaddr, which is recognized by some versions of the toolchain) is used to store the encoded value of the error instruction before entering the exception or the address value of the memory access, in order to diagnose and debug the cause of the exception. To understand this register, see Chapter 3 for a systematic understanding of exceptions. When the Bumblebee kernel enters an exception, the mtval register is updated simultaneously to reflect the current exception. 7.4.19. mip The control bit of the mip register in ECLIC interrupt mode does not work, and the read mip returns all 0s. 7.4.20. mnxti Mnxti (Next Interrupt Handler Address and Interrupt-Enable CSR) can be accessed by software to handle the next interrupt in the same Privilege Mode without causing flushing pipelines and context save # recovery. The mnxti register is accessed by the CSRRSI/CSRRCI instruction. The read return value is the handler address of the next interrupt, and the mnxti writeback operation updates the interrupt enable state. ### note: - 1 For interrupts of different Privilege Modes, the hardware is handled as interrupt nesting, so mnxti will only process the next interrupt in the same Privilege Mode. - 2 The mnxti register is not the same as the regular CSR instruction, and its return value is the RMW of the regular register. # The value of the (read-modify-write) operation is different: - There are two cases where the return value of a mnxti CSR read operation is as follows: - ◆ The return value is 0 when the following occurs. - No interrupts that can respond The highest priority interrupt is vector interrupt - ◆ When the interrupt is a non-vector interrupt, the interrupt handler entry address of this interrupt is returned. - The mnxti CSR write updates the following registers and register fields: - ◆ Mstatus is the destination register for the current RMW (read-modify-write) operation - ◆ The mcause. EXCCODE field and the interrupt id that will be updated to the current response interrupt, respectively - ◆ The mintstatus. MIL field is updated to the interrupt level (Level) of the current response interrupt. #### 7.4.21. mintstatus The mintstatus register holds the interrupt level for valid interrupts in each Privilege Mode. Table 7-7 Control bits of the minstatus register | area | Bit | desc<br>ript<br>ion | |----------|-------|--------------------------------------------| | MIL | 31:24 | Effective interrupt level for Machine Mode | | Reserved | 23: 8 | Unused field is constant 0 | | UIL | 7:0 | User Mode effective interrupt level | #### 7.4.22. mscratchcsw # The mscratchcsw register is used to exchange the destination register with the value of mscratch to speed up interrupt handling when switching between multiple privileged modes. Use the CSR instruction with a read to access mscratchesw. When the privileged mode is inconsistent before and after the interrupt occurs, there are register operations as shown in the following directive: ``` csrrw rd, mscratchcsw, rs1 // Pseudocode operation. if (mcause.mpp!=M-mode) then { t = rs1; rd = mscratch; mscratch = t; } else { rd = rs1; // mscratch unchanged. } ``` The processor interrupts in the Privilege Mode, the processor enters the high privileged mode to handle interrupt, and when processing the interrupt, the stack is needed to save the state of the processor before entering the interrupt. At this time, if you continue to use the stack pointer (SP) in privileged mode, the data of stack in the high privileged mode will be stored in the interval that the low privileged mode can access, resulting in the security of high privileged mode data leakage to the 1owprivileged mode. Vulnerabilities. To avoid this vulnerability, the RISC-V architecture specifies that when the processor is in low privileged mode, the stack pointer (SP) of the high privileged mode needs to be saved to the mscratch register, so that after entering the high privileged mode, the processor can use the mscratch register. The value of the stack pointer (SP) to restore the privileged mode. Using the normal instructions to execute the above program requires more cycles. The mscratchcsw register is defined for this RISC-V architecture. The mscratchesw register instruction is executed immediately after the interrupt is entered, and the values of mscratch and SP are exchanged to restore the stack of the high privileged mode. Pointer (SP) while backing up the low privileged mode stack pointer (SP) to the mscratch register. Before executing the mret instruction to exit the interrupt, a mscratchesw instruction is also added to exchange the value of the mscratch register and the stack pointer (SP), and the stack pointer (SP) of the high privileged mode is backed up to mscratch again, and the stack pointer of the low privileged mode is restored. (SP). In this way, only two instructions are needed to solve the stack pointer (SP) switching problem of different privileged modes, which speeds up interrupt processing. Note: To avoid virtualization vulnerabilities, the software cannot read the processor's directly current privilege mode (Privilege Mode). If the software attempts to access the mscratchcsw register swap operation in a given privileged mode in a lower privileged mode, causing processor to enter a trap, mscratchcsw does not cause **a**. virtualization vulnerability. 7.4.23. mscratchcswl The mscratchcswl register is used to exchange the destination register with the value of mscratch to speed up interrupt handling when switching between multiple interrupt levels. Use the CSR instruction with read mscratchesw. When to access privileged mode is unchanged, is a switch between there the interrupt program and the application, register operations there are as shown in the following directive: ``` csrrw rd, mscratchcswl, rs1 // Pseudocode operation. if ( (mcause.mpil==0) != (mintstatus.mil == 0) ) then { t = rs1; rd = mscratch; mscratch = t; } else { ``` rd = rs1; // mscratch unchanged. In single privileged mode. separating the interrupt handler task the from stack space of the application task can increase robustness, reduce space usage, facilitate debugging. The system interrupt handler task has a non-zero level, while the interrupt application task has a zero interrupt level, according to which mscratchcswl register is defined by RISC-V architecture. Similar mscratchesw, adding a mscratcheswl to the interrupt program entry and exit respectively enables a fast stack pointer switch between the interrupt handler and the application, ensuring separation of the stack space between the interrupt handler and the application. #### 7.4.24. Mcycle and mcycleh The risc-v architecture defines a 64-bit wide clock cycle counter that reflects how many clock cycles the processor has executed. This counter continuously increments as long as the processor is in the execution state. The mcycle register reflects the lower 32 bits of the counter, and the mcycleh register reflects the 32-bit high value of the counter. The mcycle and mcycleh registers can be used to measure processor performance and have readable and writable properties, so software can override the values in the mcycle and mcycleh registers with CSR instructions. In the implementation of the Bumblebee kernel, it is customizable because it takes into account that this counter count consumes some dynamic power. An additional control field is added to the CSR register mcountinhibit. The software can configure this control field to stop counting the counters corresponding to mcycle and mcycleh, so that the counter can be stopped to save power when performance is not required. See 7.5.1 Learn more about mcountinhibit register information. Note: This counter does not count if in debug mode, and the counter will only count in normal function mode. #### 7.4.25. Minstret and minstreth The risc-v architecture defines a 64-bit wide instruction completion counter that reflects how many instructions the processor successfully executed. This counter increments as long as the processor completes an instruction every successful execution. The minstret register reflects the lower 32 bits of the counter, and the minstreth register reflects the 32-bit high value of the counter. The minstret and minstreth registers can be used to measure processor performance and have readable and writable properties, so software can override the values in the minstret and minstreth registers with CSR instructions. Since this counter count consumes some dynamic power, in the implementation of the Bumblebee kernel, an additional control field is added to the custom CSR register mcountinhibit, and the software can configure this control field to minstret and The counter corresponding to minstreth stops counting, so that the counter is stopped to save power when performance is not required. See 7.5.1 Learn more about mcountinhibit register information. Note: This counter does not count if in debug mode, and the counter will only count in normal function mode. #### 7.4.26. Cycle and cycleh Cycle and cycleh are read-only copies of mcycle and mcycleh, respectively. Is this register readable by User Mode? The CY bit field of the CSR register mcounteren is controlled, see section 7.4.29 Learn more about it. 7.4.27. Instret and intreth Instret and intreth are read-only copies of minstret and minstreth, respectively. Whether this register is readable in User Mode is controlled by the IR bit field of the CSR register mcounteren, see section 7.4.29 Learn more about it. #### 7.4.28. Time and timeh Time and timeh are read-only copies of mtime and mtimeh, respectively. Is this register readable by User Mode? The TM bit field of the CSR register mcounteren is controlled, see section 7.4.29 Learn more about it. #### 7.4.29. mcounteren This register will only exist if it is configured to support User Mode. Each control bit field in the mcounteren register table 7-8 Table 7-8 Shown. Table 7-8 mCounteren Register Control Bits | area | Bit | description | |--------|------|---------------------------------------------------------------------------------------| | CY | 0 | This bit controls whether the cycle and cycleh registers can be accessed in User | | | | Mode: | | | | If this bit is 1, the cycle and cycleh can be accessed normally in User Mode. | | | | If this is 0, accessing cycle and cycleh in User Mode will trigger illegal | | | | instruction. | | | | Exception .Thi | | | | s bit resets the | | | | default value to | | | | 0. | | TM | 1 | This bit controls whether the time and timeh registers can be accessed in User | | | | Mode: | | | | If this bit is 1, the time and timeh can be accessed normally in User Mode. | | | | If this is 0, accessing time and timeh in User Mode will trigger illegal instruction. | | | | Exception. | | | | This bit resets the default value to 0. | | IR | 2 | This bit controls whether the instret and intreth registers can be accessed in User | | | | Mode: | | | | If this bit is 1, the instret and instreth can be accessed normally in User Mode. | | | | If this is 0, accessing instret and instreth in User Mode will trigger illegal | | | | instruction. | | | | Exception. | | | -~- | This bit resets the default value to 0. | | Reserv | 3~31 | Other unused fields are constants O | | ed | | | #### 7.5. Bumblebee kernel custom CSR This section describes the CFF registers customized by the Bumblebee kernel. #### 7.5.1. mcountinhibit The mcountinhibit register is used to # control the count of mcycle and minstret, each control bit field such as Table 7-9 Table 7-9 Shown. Table 7-9 Control bits of mcountinhibit register | area | Bit | desc<br>ript<br>ion | |----------|------|---------------------------------------------------| | Reserved | 31:3 | Unused field is constant 0 | | IR | 2 | The count of minstret is turned off when IR is 1. | | Reserved | 1 | Unused field is constant 0 | | СҮ | 0 | Count of mcycle is turned off when CY is 1 | #### 7, 5, 2, mnyec The mnvec register is used to configure the entry address of the NMI In order to understand this register, please refer to Chapter 4 for a systematic understanding of nmi. During the execution of the processor program, once the NMI encounters, the current program flow is terminated, the processor is forced to jump to a new PC address, and the PC address jumped into the NMI after the Bumblebee kernel enters the NMI is specified by the mnvec register. . Note: The value of mnvec is controlled by mmisc\_ctl. For more details, please refer to 7.5.4 Section. #### 7. 5. 3. msubm The Bumblebee kernel custom msubm register is used to hold the Trap type before and after the Trap. Each control bit field in the msubm register is as Table 7-10 Table 7-10 Shown. Table 7-10 msubm Register Control Bits | area | Bit | desc<br>ript<br>ion | |----------|-------|--------------------------------------------------------------------------------------------------| | Reserved | 31:10 | Unused field is constant 0 | | PTYP | 9:8 | Save the Trap type before entering Trap: 0: Non-Trap status 1: interrupt 2: abnormal 3: NMI | | TYP | 7:6 | Indicates the current Trap type of the Core: 0: Non-Trap status 1: interrupt 2: abnormal 3: NMI | | Reserved | 5:0 | Unused field is constant 0 | The Bumblebee kernel custom mmisc\_ctl register is used to control the mcause values of mnvec and NMI. Each control bit field in the mmisc\_ctl register Table 7-11 Table 7-11 Shown. Table 7-11 Control bits of the mmisc\_ctl register | area | Bit | desc<br>ript<br>ion | |----------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Reserved | 31:10 | Unused field is constant 0 | | NMI_CAUSE_ FFF | 9 | Control meause. EXCCODE for mnvec and NMI: 0: The value of mnvec is equal to the PC after processor reset, NMI meause. EXCCODE is 0x1 1: The value of mnvec is the same as mtvec, and the meause. EXCCODE of NMI is 0xfff | | Reserved | 8:0 | Unused field is constant 0 | #### 7.5.5. msavestatus Msavestatus is used to store the values of mstatus and msubm ensure that the state of each domain of mstatus and msubm is not flushed by NMI or exceptions. Msavestatus has a two-stage stack that supports up to 3 levels of exception/NMI state saving. For two-level more NMI/Exception Status Stack, see # Section 4.6. Each control bit of the msavestatus register is as <u>Table 7-12 Table 7-12</u> Shown. | | Table | 1-12 msavestatus kegister Control Bits | |----------|-------|-------------------------------------------------------------------------------------| | area | Bit | desc<br>ript<br>ion | | Reserved | 31:16 | Unused field is constant 0 | | PTYP2 | 15:14 | Second-level nested NMI/Trap type before exception occurs | | Reserved | 13:11 | Unused field is constant 0 | | MPP2 | 10:9 | Second-level nested NMI/Privilege mode before exception occurs | | MPIE2 | 8 | The second level of nested nmi / interrupt enable state before the exception occurs | | PTYP1 | 7:6 | The first level of nested NMI / Trap type before the exception occurs | | Reserved | 5:3 | Unused field is constant O | | MPP1 | 2:1 | The first level of nested NMI / Privilege mode before the exception occurs | | MPIE1 | 0 | The first level of nested nmi / interrupt enable state before the exception occurs | Table 7-12 msavestatus Register Control Bits #### 7.5.6. Msaveepc1 and msaveepc2 Msaveepc1 and msaveepc2 are used as the primary NMI/exception state stack and the secondary 设置 NMI/exception state stack, respectively, to store the PC before the first-level nested NMI/abnormality, and the PC before the second-level nested NMI/abnormality. . msaveepc2 <= msaveepc1 <= mepc <= interrupted PC <= NMI/exception PC</p> When executing the mret instruction, while mcause. INTERRUPT is 0 (eg NMI, or exception), msaveepc1 and Msaveepc2 recovers the processor's PC through the primary and secondary NMI/Exception Status Stacks, respectively. msaveepc2 => msaveepc1 => mepc => PC #### 7. 5. 7. Msavecause1 and msavecause2 Msavecause1 and msavecause2 are used as a level 1 NMI/Exception State Stack and a Level 2 NMI/Exception State Stack, respectively, to store the first level of nested NMI/mcause before the exception occurs, and the second level of nested NMI/mcause before the exception occurs. . msavecause2 <= msavecause1 <= mcause <= NMI/exception cause</p> When executing the mret instruction while mcause. INTERRUPT is 0 (eg NMI, or exception), msavecause1 And msavecause2 restores the mcause state through the primary and secondary NMI/Exception State Stacks, respectively. msavecause2 => msavecause1 => mcause #### 7.5.8. pushmsubm The Bumblebee kernel defines CSR instructions implemented by the csrrwi operation of the pushmsubm register, storing The value of msubm to the stack pointer is used as the memory space of the base address. This CSR instruction is described by taking the following ## instruction as an # example: csrrwi x0, PUSHMSUBM, 1 The operation of this instruction is to store the value of the msubm register to the address of SP (stack pointer) + 1 \* 4. #### 7. 5. 9. mtvt2 Mtvt2 is used to specify the interrupt common-code entry address for ECLIC non-vector mode. Each control bit field in the mtvt2 register is as Table 7-13 Table 7-13 Shown. Table 7-13 mtvt2 register control bits | area | Bit | desc<br>ript<br>ion | |-----------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CMMON-COD E-<br>ENTRY | 31:2 | This field determines the ECLIC non-vector mode interrupt when mtvt2.MTVT2EN=1 Common-code entry address. | | Reserved | 1 | Unused field is constant 0 | | MTVT2EN | 0 | Mtvt2 enable bit: 0: ECLIC non-vector mode interrupt common-code entry address by mtvec Decide 1: ECLIC non-vector mode interrupt common-code entry address by mtvt2. COMMON-CODE-ENTRY decision | #### 7.5.10. jalmnxti The Bumblebee kernel defines the jalmnxti register to reduce interrupt latency and speed up interrupt tail biting. Jalmnxti In addition to the mnxti enable interrupt enable, processing the next interrupt, return to the next interrupt entry address and other functions, there is a jump to the interrupt handler function, so the number of interrupt processing instructions can be shortened, reducing interrupts Delay, speed up the purpose of interrupting the tail bite. For more details on jalmnxti please see **5.13.1.3** Section. #### 7.5.11. pushmcause The Bumblebee kernel defines a CSR instruction implemented by the csrrwi operation of the pushmcause register, storing The value of mcause to the stack pointer is used as the memory space of the base address. This CSR instruction is described by taking the following instruction as an ### example: csrrwi x0, PUSHMCAUSE, 1 The operation of this instruction is to store the value of the mcause register to the address of SP (stack pointer) + 1 \* 4. ### 7.5.12. pushmepc The Bumblebee kernel defines a CSR instruction implemented by the csrrwi operation of the pushmepc register, storing the mepc The value of the stack pointer to the memory space of the base address Introduce this csr instruction with the following instruction as an example: The operation of this instruction is to store the value of the mepc register to the address of SP (stack pointer) + 1 \* 4. #### 7.5.13. sleepvalue The Bumblebee kernel customizes a CSR register sleepvalue to control different sleep modes, see section 8.1 For more details. Each control bit field in the sleepvalue register Table 7-14 Shown. | Table | 7-14 | sleepvalue | register | ${\tt control}$ | bits | |-------|------|------------|----------|-----------------|------| | Bit. | | | , | desc | | | area | Bit | desc<br>ript<br>ion | | |------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | SLEEPVALUE | 0 | Control wfi sleep mode 0: Shallow sleep mode (the main working clock of the processor core after executing wfi Core_clk is closed) 1: Deep sleep mode (the main working clock of the processor core after executing wfi Core_clk and the processor core's normally open clock | | | | | core_aon_clk are both turned off) This bit resets the default value to 0. | |----------|------|---------------------------------------------------------------------------| | Reserved | 31:1 | Unused field is constant 0 | #### 7. 5. 14. txevt The Bumblebee kernel has a custom CSR register, txevt, for sending events to the outside world. Each control bit field in the txevt register Table 7-15 Table 7-15 Shown. Table 7-15 txevt Register Control Bits | area | Bit | desc<br>ript<br>ion | |----------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | TXEVT | 0 | Control to send Event: If you write 1 to this bit, it will trigger the output signal tx_evt of the Bumblebee kernel. A single-cycle pulse signal is generated as an external Event signal. This bit is a self-clearing bit, that is, after a 1 is written to this bit, it is self-cleared to 0 in the next cycle. Writing 0 to this bit has no reaction or operation. This bit resets the default value to 0. | | Reserved | 31:1 | Unused field is constant 0 | 7.5.15. wfe The Bumblebee kernel has a custom CSR register wfe that controls whether the WFI instruction wakes up using an interrupt or an Event. See section 8.2.3 For more details. Each control bit field in the wfe register Table 7-16 Table 7-16 Shown. area Bit desc ript ion WFE The wake-up condition that controls the WFI instruction is whether to use an interrupt or an Event. 0: The processor core can be interrupted and nmi wake up when it enters sleep mode. 1: When the processor core enters sleep mode, it can be woken up by Event and NMI. This bit resets to a default of 0. Reserved 31:1 Unused field is constant 0 Table 7-16 Control bits of the wfe register 8. Introduction to the Bumblebee core low power mechanism The Bumblebee core can support sleep mode for lower static power consumption. #### 8.1. Go to sleep The Bumblebee kernel can go to sleep through the WFI instruction. When the processor executes the WFI instruction it will: - Immediately stop executing the current instruction stream; - Waiting for the processor core to complete any outstanding outstanding operations (Outstanding Transactions), such as fetching instructions and data read and write operations, to ensure that the operations sent to the bus are completed; - Note: If a memory access error exception occurs while waiting for an operation on the bus to complete, it will enter the exception handling mode without sleeping. - When all of the Outstanding Transactions are completed, the processor safely enters an idle state, which can be referred to as a "sleep" state. - When entering sleep mode: - The clocks of the main units inside the Bumblebee core will be gated off to save static power consumption; - The output signal core\_wfi\_mode of the Bumblebee kernel is pulled high, indicating that this processor core is executing WFI ### The sleep state after the instruction; • The Bumblebee kernel's output signal core\_sleep\_value will output the value of the CSR register sleepvalue (note: this signal is only valid when the core\_wfi\_mode signal is high; the core\_sleep\_value must be 0 when the core\_wfi\_mode signal is low). Software can configure the CSR register by prior # Sleepvalue to indicate a different sleep mode (0 or 1).note: ◆ The Bumblebee kernel behaves exactly the same for different sleep modes. This sleep mode is only for the corresponding control of the PMU (Power Management Unit) at the SoC system level. #### 8.2. Exit hibernation The main points of the Bumblebee kernel processor exiting sleep mode are as follows: - The output signal core\_wfi\_mode of the Bumblebee kernel is pulled low accordingly. - The Bumblebee kernel processor can be woken up in four ways: - NMI - Interrupt - Event - Debug request This will be described in detail below #### 8.2.1. Nmi wake up NMI can always wake up the processor core. When the processor core detects a rising edge of the input signal nmi, the processor core wakes up and proceeds to the NMI service routine to begin execution. #### 8.2.2. Interrupt wakeup # Interrupts can also wake up the processor core: - If the mstatus.MIE field is configured to 1 (indicating that the global interrupt is turned on): - When eclic (by arbitrating an externally requested interrupt) sends an interrupt to the processor core, the processor core wakes up and proceeds to the interrupt service routine to begin execution. - If the mstatus.MIE field is configured to 0 (indicating that the global interrupt is closed): - If the CSR register wfe. WFE field is configured to 0, then: - ◆ When eclic (by arbitrating an externally requested interrupt) sends an interrupt to the processor core, the processor core wakes up and continues to execute the previously stopped instruction stream (instead of entering the interrupt service routine). • If the CSR register wfe. WFE field is configured to 1, then wait for Event wakeup, see the description in the next section. #### 8.2.3. Event wake up # Event can wake up the processor core when the following conditions are met: - If the mstatus.MIE field is configured to 0 (indicating that the global interrupt is turned off) and the CSR register wfe.WFE field is configured to 1, then: - When the processor core detects that the input signal rx\_evt (called the Event signal) is high, the processor core wakes up and continues executing the previously stopped instruction stream (instead of entering the interrupt service routine). #### 8.2.4. Debug wake up The Debug request always wakes up the processor core. If the debugger is Debugged, it will wake up the processor core and enter debug mode. The Wait for Interrupt mechanism refers to putting the processor core into sleep mode, then waiting for the interrupt to wake up the processor core, and waking up to the corresponding interrupt handler. Such as the first **8.1** Festival and section **8.28.2** As mentioned in the section, the Wait for Interrupt mechanism can directly pass the WFI instruction (cooperate The mstatus. MIE field is configured to 1) complete. ### 8.4. Wait for Event mechanism The Wait for Event mechanism refers to putting the processor core 갶 into sleep mode, then waiting for Event to wake up the processor core, and waking up to continue the previously stopped program (instead of entering the interrupt handler). Such as the first **8.1** Festival and section **8.28.2** As mentioned in the section, the Wait for Event mechanism can directly pass the WFI instruction with the following instructions. Sequence completion: Step 1: Configure the mstatus.MIE field to 0 to turn off global interrupts Step 2: Configure the wfe.WFE domain to be 1 Step 3: Call the WFI instruction.After this instruction is called, the processor enters sleep mode and will continue to execute downwards when Event or NMI wakes up. Step 4: Restore the wfe.WFE field to 0 Step 5: Restore the mstatus.MIE field to the previous value