Date: 2022/08/30

Task Group: Fast Interrupts

Chair: Dan Smathers

Co-Chair: Kevin Chen

Number of Attendees: 5

Meetings Disclaimers Video:

https://drive.google.com/file/d/1y XWJus8M5ZwSQ2cvEOzCjlOmsmXOnN4/view

Current issues on github: <a href="https://github.com/riscv/riscv-fast-interrupt/issues">https://github.com/riscv/riscv-fast-interrupt/issues</a>

Previous meeting minutes: <a href="https://github.com/riscv/riscv-fast-interrupt/tree/master/minutes">https://github.com/riscv/riscv-fast-interrupt/tree/master/minutes</a>

Fast Interrupt DoD (Definition of Done) Status: (new location) <a href="https://wiki.riscv.org/display/HOME/Fast+Interrupts+TG">https://wiki.riscv.org/display/HOME/Fast+Interrupts+TG</a>

### Next meeting agenda (09/13/22)

review next time if #240 and #255 can be closed.

### **Meeting minutes**

Discussed possible fast interrupt update presentation at riscv summit in december.

Pull #258 - If system uses both modes, CLINT put together. review next time if #240 and #255 can be closed.

Pull #259 – clicintattr.mode WARL for #229

Pull #260 – text clarification for #219

Pull #262 – clarification of sw vectoring read permission #191

Pull #261 – dret clarification for #239/ #228

## Github updates since last minutes:

**Specification updates since last minutes:** 

**Open issue status:** 

Issues that can be closed? (Simpler issues to discuss in red)

#222 – legacy s-mode/u-mode timer interrupt setup, closed by pull #263?

#240 – change mscratchesw to use mstatus.mpp in pseudocode? does it matter if not visible in non-clic mode? Need to update text to clarify. closed by pull #258?

## **Need spec updates:**

- #49 reopened: prev spec had single control for multiple harts but current spec implies control per hart and implications. Closed by #231? Dependent on issue #96/226 discussion?
- #75 move hw vectoring to separate section in spec waiting until other issue spec updates before making this large text change.
- #158 change CLICCTRLBITS to CLICMLPBITS. (resolve #226 first?)
- #171 CLICCFGLBITS parameter related to #80, #158. (resolve #226 first)
- #160/200 can rewrite to allow for but not assume n-extension is available. probably combine
- #221 compressed clicintip/clicintie status registers (1-bit per interrupt) similar to AIA eip0-eip63? Add justification and create a pull with a proposal.
- #255 CLIC/CLINT wording clarification. Pull #258. Still need to review wording, maybe bring comments from different sections together in one area.

#### **Need more discussion:**

- #96 proposed reformat of cliccfg. bit spec change, small hw change. Tried to close with Pull #183. more discussion about xcliccfg.nmbits. change to a programmable boundary value? discuss more. created a new pull #231 to go thru change implications. Separated xcliccfg.mlvl proposal to issue #226.
- **#102** preemptible interrupt handler code (for section 7.2)
- #205 xnxti side-effect question. csrrsi rd, mnxti, uimm[4:0]. Pseudo-code shows uimm needs to be non-zero to cause side-effects (updating mintstatus, mcause.exccode/interupt). Is this restriction necessary? Related to #100/#211?
- #226 proposal to replace clicintattr.mode with xcliccfg.xlvl
- #235 xcause.X updated on exceptions wording. help with more precise wording?
- #226 replace clicintattr.mode with xcliccfg.xlvl proposal (formerly #96)
- #247 behavior when MPP is two-bits and hypervisor not implemented
- #248 CLIC hypervisor mode (related to #92).

#### Issues need to be worked:

- #91 DTS entry have linux group review DTS example.
- #107 heritage of features. keep researching and adding references to bibliography.
- #185 SAIL model implementation of CLIC (probably waiver)
- #186 CLIC architecture tests
- #187 QEMU CLIC implementation update

#242 – spike required if sail is waived?

# Issues waiting on ratification (encoding/opcode consistency review needed)

#88 – CSR address mapping

# Issues punted for rev1, keep open for future enhancements:

#92/Pull #181 – hypervisor compatibility. Pull #181 with Initial hypervisor extension proposal for CLIC. Punted for rev1.

#99 – horizontal interrupt window. punted for rev1

#101 - xnxti to trigger on equal level. punted for rev1

#106 – allow level change. Punted for rev1

#108 – pushint/popint? defer to broader discussion on providing hardware stacking of interrupt contexts. Punted for rev1

#192 – allow mix of CLIC/CLINT at different priv modes punted for rev1