Date: 2022/03/29

Task Group: Fast Interrupts

Chair: Dan Smathers

Co-Chair: Kevin Chen

Number of Attendees: 6

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: https://github.com/riscv/riscv-fast-interrupt/tree/master/minutes

Fast Interrupt DoD (Definition of Done) Status:

https://wiki.riscv.org/display/TECH/Fast+Interrupts+TG

### Next meeting agenda (04/12/22)

Discuss if can close #97

Planning on splitting mclicefg/sclicefg. Split #96 into 2 issues: 1. xclicefg 2. mlvl proposal

More open issue discussion? Discuss if pulls resolve discussed issues.

Discuss issue #29/pull #190 – clicinttrig

Discuss #195/pull #196 – clarification of intthresh and xstatus.xie

Discuss #197/pull #198 – clarification of executing a lower-priv xRET on intstatus and inhv.

Discuss #160/#200/pull #201 – user mode interrupts

#### **Meeting minutes**

#220 – not going to require reserved does anything. don't put anything there. It might get stomped on. (custom region). if you don't have something there what do you do? because it is reserved, any kind of trap is ok. reserved addresses might not be elsewhere in riscv specs. don't want to require a trap. if clicv2 uses it and clicv1 traps, clicv1 is incompatible. up to platform to decide what happens. allowed but not required. create pull to clean up text.

#219 – is interrupt ordering in conflict with AIA now? (AIA uses 12 as Supervisor guest external interrupt) The table just shows the numbering. Table just reserves a few low priority ints. just matches ids used in clint mode. AIA is still discussing how to handle local interrupts. part of a larger discussion. keeping issue open.

#96 – more discussion of proposal of using clicintctl level value compared to xcliccfg xlvl to determine interrupt priv instead of using clicintattr.mode bits to determine priv (saves number of flops implemented per interrupt). A concern with the proposal is can't just use aperture writes to prevent clicintctrl from writing >=mlvl since there is state in the CLIC (clicintattr.shv,

clicintattr.trig). Will split into two issues. one adding scliccfg. one continuing discussion of using clicintctl level determine priv.

Benefits? possible to save 1 bit per interrupt. Do clic implementation area comparison saving % calculation?

### Github updates since last minutes:

# Specification updates since last minutes:

### **Open issue status:**

## Issues that can be closed? (simpler issues to discuss in blue)

#29/#155 – clarify inttrig details. Created Pull #190. debug spec added tmexttrigger.intctl to support triggers from attached interrupt controllers. Will this provide the desired tightly integrated behavior? Need to mention behavior in clic spec, e.g., breakpoint before 1<sup>st</sup> instruction of interrupt executed?

#197/pull #198 – clarification of executing a lower-priv xRET on intstatus and inhv.

#160/200 - can rewrite to allow for but not assume n-extension is available. probably combine #160 with #200. closed by pull #201?

#214/pull #215 – xscratchcsw pseudo-code (similar to #197 pseudo-code)

#195 – update spec to allow implementing a minimum number of bits of intthresh. Close with pull #217?

#218 – typo fix (dependent on #96 resolution)

#### **Need spec updates:**

#75 – move hw vectoring to separate section in spec - waiting until other issue spec updates before making this large text change.

#100 – reserve usage of immediate bits (0-UIE?),2,4 in xnxti imm usage since those mstatus bits are WPRI. Related to #205/211

#158 – change CLICCTRLBITS to CLICMLPBITS. (resolve #96 first)

#202/pull #203 – generalize statement about 32-bit writes to clic mem mapped registers. Need to update pull based on TG discussion

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

#49 – reopened: prev spec had single control for multiple harts but current spec implies control per hart and implications. Closed by #183? Dependent on issue #96 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 #204 to go thru change implications.

- #97 proposed reformat of xcause CSRs (bigger discussion). Think some assumptions might be wrong. to discuss with John Hauser.
- #102 preemptible interrupt handler code (for section 7.2)
- #108 pushint/popint? defer to broader discussion on providing hardware stacking of interrupt contexts (possibly post-1.0)..
- #171 CLICCFGLBITS parameter related to #80, #158. (resolve #96 first)
- #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?
- #208 add note about fence.i required after modification of the hardware vector table? Close with pull #206?
- #211 xnxti text vs. Pseudo-code clarification required. Related to #100/205?
- #212 NUM\_INTERRUPT parameter values. Close with pull #216?
- #213 how does CLICMTVECALIGN match AIA and code-size reduction. Close with pull #216?
- #219 Interrupt ID ordering recommendations
- #220 Access to reserved address space OK for implementation to generate access fault (not required but allowed?)
- #221 compressed clicintip status registers (1-bit per interrupt) similar to AIA eip0-eip63?

#### 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
- #186 CLIC architecture tests
- #187 QEMU CLIC implementation update

# 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

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