forked from riscv-non-isa/riscv-arch-test
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add m-mode interrupt test-cases using clint method of interrupt gener…
…ation M-mode interrupt test-cases using msw and mtimer clint interrupts Signed-off-by: Dan Smathers <[email protected]>
- Loading branch information
1 parent
821e30e
commit 0955909
Showing
1 changed file
with
343 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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 | ||
---- |