Skip to content

Commit

Permalink
Add m-mode interrupt test-cases using clint method of interrupt gener…
Browse files Browse the repository at this point in the history
…ation

M-mode interrupt test-cases using msw and mtimer clint interrupts

Signed-off-by: Dan Smathers <[email protected]>
  • Loading branch information
dansmathers authored Feb 6, 2024
1 parent 821e30e commit 0955909
Showing 1 changed file with 343 additions and 0 deletions.
343 changes: 343 additions & 0 deletions riscv-test-suite/rv32i_m/Smclint/src
Original file line number Diff line number Diff line change
@@ -0,0 +1,343 @@
==== msw-01.S
.Description: tests if RVMODEL_SET_MSW_INT is working, hangs in infinite loop otherwise
- enable mie CSR
- generate interrupt
- enable mstatus.mie
- trigger m-mode handler
- clear interrupt
- set mepc to finish
- mret to finish
[%autofit]
----
RVMODEL_SET_MIE = MIE_MSIE
RVMODEL_SET_INT1 = RVMODEL_SET_MSW_INT
RVMODEL_SET_INT2 = <EMPTY>
RVMODEL_CLEAR_INT1 = RVMODEL_CLEAR_MSW_INT
RVMODEL_CLEAR_INT2 = <EMPTY>
RVMODEL_WFI = jump_to_self
----
Coverage
----
msip trigger | verify RVMODEL_SET_MSW_INT trigger
msip clear | verify RVMODEL_CLEAR_MSW_INT clear
mip.msip | verify mip signature 0/1
mcause | verify machine software interrupt signature
mstatus | verify mstatus.mie/mpie/mpp signature in interrupt handler and after mret
mtvec | verify interrupt uses mtvec to calculate pc of interrupt handler (direct)
mepc | verify mepc location is jump_to_self location
----
==== mtimer-01.S
.Description: tests if RVMODEL_SET_MTIMER_INT is working, hangs in infinite loop otherwise
- enable mie CSR
- generate interrupt
- enable mstatus.mie
- trigger m-mode handler
- clear interrupt
- set mepc to finish
- mret to finish
[%autofit]
----
RVMODEL_SET_INT1 = RVMODEL_SET_MTIMER_INT
RVMODEL_SET_INT2 = <EMPTY>
RVMODEL_CLEAR_INT1 = RVMODEL_CLEAR_MTIMER_INT
RVMODEL_CLEAR_INT2 = <EMPTY>
RVMODEL_WFI = jump_to_self
----
Coverage
----
mtip trigger | verify RVMODEL_SET_MTIMER_INT trigger
mtip clear | verify RVMODEL_CLEAR_MTIMER_INT clear
mip.mtip | verify mip signature 0/1
mcause | verify machine timer interrupt signature
mstatus | verify mstatus.mie/mpie/mpp signature in interrupt handler and after mret
mtvec | verify interrupt uses mtvec to calculate pc of interrupt handler (direct)
mepc | verify mepc location is jump_to_self location
----
==== nomint-01.S
.Description: expect interrupts will not trigger in m-mode unless mstatus.mie is set
- enable mie
- generate interrupts
- nop
- jump to finish
[%autofit]
----
RVMODEL_MSTATUS_MIE = 0
RVMODEL_SET_INT1 = RVMODEL_SET_MSW_INT
RVMODEL_SET_INT2 = RVMODEL_SET_MTIMER_INT
RVMODEL_CLEAR_INT1 = RVMODEL_CLEAR_MSW_INT
RVMODEL_CLEAR_INT2 = RVMODEL_CLEAR_MTIMER_INT
RVMODEL_WFI = nop
----
Coverage
----
mstatus.mie | verify no interrupt occurs in m-mode if mstatus.mie is 0
----
==== nomint-02.S
.Description: expect interrupts will not trigger in m-mode unless mie.x is set
- generate interrupts
- enable mstatus.mie
- nop
- jump to finish
[%autofit]
----
RVMODEL_SET_MIE = 0
RVMODEL_SET_INT1 = RVMODEL_SET_MSW_INT
RVMODEL_SET_INT2 = RVMODEL_SET_MTIMER_INT
RVMODEL_CLEAR_INT1 = RVMODEL_CLEAR_MSW_INT
RVMODEL_CLEAR_INT2 = RVMODEL_CLEAR_MTIMER_INT
RVMODEL_WFI = nop
----
Coverage
----
mie.msip | verify no msw interrupt occurs if mie.msip is 0
mie.mtip | verify no mtimer interrupt occurs if mie.mtip is 0
----
==== wfi-01.S
.Description: expect wfi to behave like a nop when a single interrupt is pending when mstatus.mie is disabled
- enable mie CSR
- generate interrupts
- wfi
- wakeup
- jump to finish
[%autofit]
----
RVMODEL_MSTATUS_MIE = 0
RVMODEL_SET_MIE = MIE_MSIE
RVMODEL_SET_INT1 = RVMODEL_SET_MSW_INT
RVMODEL_SET_INT2 = RVMODEL_SET_MSW_INT
RVMODEL_CLEAR_INT1 = RVMODEL_CLEAR_MSW_INT
RVMODEL_CLEAR_INT2 = RVMODEL_CLEAR_MSW_INT
----
Coverage
----
mstatus.mie | verify no interrupt occurs in m-mode if mstatus.mie is 0
wfi | verify wakeup/nop occurs with mstatus.mie = 0
wfi | verify wakeup/nop occurs with pending interrupt
----
==== direct-01.S
.Description: trigger, clear, retrigger same interrupt.
- enable mie CSR
- generate interrupt
- enable mstatus.mie
- trigger m-mode handler
- clear 1st interrupt
- generate interrupt
- trigger 2nd m-mode handler
- clear 2nd interrupt
- set mepc to finish
- mret to finish
[%autofit]
----
RVMODEL_SET_MIE = MIE_MSIE
RVMODEL_SET_INT1 = RVMODEL_SET_MSW_INT
RVMODEL_SET_INT2 = RVMODEL_SET_MSW_INT
RVMODEL_CLEAR_INT1 = RVMODEL_CLEAR_MSW_INT
RVMODEL_CLEAR_INT2 = RVMODEL_CLEAR_MSW_INT
----
Coverage - same as msw-01.S plus
----
mtvec.mode | verify direct mode is used to handle interrupt
msip retrigger | verify after mstatus.mie is enabled in interrupt handler, msip will retrigger
----
==== direct-02.S
.Description: trigger, clear, retrigger single interrupt, no 2nd clear.
Stimulates pending interrupt after setting mstatus.mpie followed by mret
mstatus.mie should be cleared after mret so pending interrupt is not taken
- enable mie CSR
- generate interrupt
- enable mstatus.mie
- trigger m-mode handler
- clear 1st interrupt
- generate interrupt
- trigger 2nd m-mode handler
- set mepc to finish
- clear mstatus.mpie
- mret to finish
[%autofit]
----
RVMODEL_SET_MIE = MIE_MSIE
RVMODEL_SET_INT1 = RVMODEL_SET_MSW_INT
RVMODEL_SET_INT2 = RVMODEL_SET_MSW_INT
RVMODEL_CLEAR_INT1 = RVMODEL_CLEAR_MSW_INT
RVMODEL_CLEAR_INT2 = <EMPTY>
----
Coverage - same as msw-01.S plus
----
msip retrigger | verify after mstatus.mie is enabled after mret, msip will retrigger
----
==== vectored-01.S
.Description: trigger, clear, retrigger single interrupt, vectored-mode.
- enable mie CSR
- generate interrupt
- enable mstatus.mie
- trigger vectored m-mode handler
- clear 1st interrupt
- generate interrupt
- trigger 2nd vectored m-mode handler
- clear 2nd interrupt
- set mepc to finish
- mret to finish
[%autofit]
----
RVMODEL_SET_MIE = MIE_MSIE
RVMODEL_MTVEC_MODE = 1
RVMODEL_SET_INT1 = RVMODEL_SET_MSW_INT
RVMODEL_SET_INT2 = RVMODEL_SET_MSW_INT
RVMODEL_CLEAR_INT1 = RVMODEL_CLEAR_MSW_INT
RVMODEL_CLEAR_INT2 = RVMODEL_CLEAR_MSW_INT
----
Coverage - same as msw-01.S plus
----
mtvec.mode | verify vectored mode is used to handle interrupt
msip retrigger | verify after mstatus.mie is enabled in interrupt handler, msip will retrigger
----
==== vectored-02.S
.Description: trigger, clear, retrigger single interrupt, no 2nd clear.
Stimulates pending interrupt after setting mstatus.mpie followed by mret, vectored-mode.
mstatus.mie should be cleared after mret so pending interrupt is not taken
- enable mie CSR
- generate interrupt
- enable mstatus.mie
- trigger vectored m-mode handler
- clear 1st interrupt
- generate interrupt
- trigger 2nd vectored m-mode handler
- set mepc to finish
- clear mstatus.mpie
- mret to finish
[%autofit]
----
RVMODEL_SET_MIE = MIE_MSIE
RVMODEL_MTVEC_MODE = 1
RVMODEL_SET_INT1 = RVMODEL_SET_MSW_INT
RVMODEL_SET_INT2 = RVMODEL_SET_MSW_INT
RVMODEL_CLEAR_INT1 = RVMODEL_CLEAR_MSW_INT
RVMODEL_CLEAR_INT2 = <EMPTY>
----
Coverage - same as msw-01.S plus
----
mtvec.mode | verify vectored mode is used to handle interrupt
msip retrigger | verify after mstatus.mie is enabled after mret, msip will retrigger
----
==== ecall-01.S
.Description: trigger, clear, set interrupt pending, ecall
Stimulates ecall within an interrupt handler to stimulate mcause.interrupt toggling
mstatus.mie should be cleared after mret so pending interrupt is not taken
- enable mie CSR
- generate interrupt
- enable mstatus.mie
- trigger m-mode vectored interrupt handler
- ecall instruction to trigger (direct) exception handler
- set mepc to finish
- clear mstatus.mpie
- mret to finish
- re-trigger interrupt
[%autofit]
----
RVMODEL_SET_MIE = MIE_MSIE
RVMODEL_MTVEC_MODE = 1
RVMODEL_SET_INT1 = RVMODEL_SET_MSW_INT
RVMODEL_SET_INT2 = <EMPTY>
RVMODEL_CLEAR_INT1 = <EMPTY>
RVMODEL_CLEAR_INT2 = <EMPTY>
RVMODEL_ECALL = ecall
----
Coverage - same as msw-01.S plus
----
mtvec.mode | verify vectored mode is used to handle interrupt
mcause.interrupt 0/1 | verify ecall toggles mcause.interrupt, uses direct exception handler
----
==== level-01.S
.Description: verify interrupt level order, 2 interrupts asserted in 1st interrupt handler, mtvec.mode=direct
- enable mie CSR
- generate interrupt 1
- enable mstatus.mie
- trigger m-mode handler
- generate interrupt 2 (both interrupts now pending)
- trigger 2nd m-mode handler
- set mepc to finish
- clear mstatus.mpie
- mret to finish
[%autofit]
----
RVMODEL_SET_INT1 = RVMODEL_SET_MSW_INT
RVMODEL_SET_INT2 = RVMODEL_SET_MTIMER_INT
RVMODEL_CLEAR_INT1 = <EMPTY>
RVMODEL_CLEAR_INT2 = RVMODEL_CLEAR_MTIMER_INT
----
Coverage
----
Interrupt ordering - both interrupts asserted in msw interrupt handler
----
==== level-02.S
.Description: verify interrupt level order, swap 2 interrupt order, mtvec.mode=direct
- enable mie CSR
- generate interrupt 1
- enable mstatus.mie
- trigger m-mode handler
- generate interrupt 2 (both interrupts now pending)
- set mstatus.mie
- trigger 2nd m-mode handler
- set mepc to finish
- clear mstatus.mpie
- mret to finish
[%autofit]
----
RVMODEL_SET_INT1 = RVMODEL_SET_MTIMER_INT
RVMODEL_SET_INT2 = RVMODEL_SET_MSW_INT
RVMODEL_CLEAR_INT1 = <EMPTY>
RVMODEL_CLEAR_INT2 = RVMODEL_CLEAR_MSW_INT
----
----
Interrupt ordering - both interrupts asserted in mtimer interrupt handler
----
==== level-03.S
.Description: verify interrupt level order, 2 interrupts asserted in 1st interrupt handler, mtvec.mode=vectored
- enable mie CSR
- generate interrupt 1
- enable mstatus.mie
- trigger vectored m-mode handler
- generate interrupt 2 (both interrupts now pending)
- set mstatus.mie
- trigger 2nd vectored m-mode handler
- set mepc to finish
- clear mstatus.mpie
- mret to finish
[%autofit]
----
RVMODEL_MTVEC_MODE = 1
RVMODEL_SET_INT1 = RVMODEL_SET_MSW_INT
RVMODEL_SET_INT2 = RVMODEL_SET_MTIMER_INT
RVMODEL_CLEAR_INT1 = <EMPTY>
RVMODEL_CLEAR_INT2 = RVMODEL_CLEAR_MTIMER_INT
----
Coverage
----
mtvec.mode | verify vectored mode is used to handle interrupt, signature of higher priority interrupt
Interrupt ordering | both interrupts asserted in msw interrupt handler
----
==== level-04.S
.Description: verify interrupt level order, swap 2 interrupt order, mtvec.mode=vectored
- enable mie CSR
- generate interrupt 1
- enable mstatus.mie
- trigger vectored m-mode handler
- generate interrupt 2 (both interrupts now pending)
- set mstatus.mie
- trigger 2nd vectored m-mode handler
- set mepc to finish
- clear mstatus.mpie
- mret to finish
[%autofit]
----
RVMODEL_MTVEC_MODE = 1
RVMODEL_SET_INT1 = RVMODEL_SET_MTIMER_INT
RVMODEL_SET_INT2 = RVMODEL_SET_MSW_INT
RVMODEL_CLEAR_INT1 = <EMPTY>
RVMODEL_CLEAR_INT2 = RVMODEL_CLEAR_MSW_INT
----
Coverage
----
mtvec.mode | verify vectored mode is used to handle interrupt, signature of higher priority interrupt
Interrupt ordering | both interrupts asserted in mtimer interrupt handler
----

0 comments on commit 0955909

Please sign in to comment.