forked from josecm/riscv-hyp-tests
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathinterrupt_tests.c
95 lines (79 loc) · 2.85 KB
/
interrupt_tests.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
#include <rvh_test.h>
bool check_xip_regs(){
TEST_START();
CSRW(mideleg, 0);
int64_t mtime_mask = ~((int64_t)0x80);
CSRW(mideleg, (uint64_t)-1);
VERBOSE("setting mideleg and hideleg\n");
CSRW(CSR_HIDELEG, (uint64_t)-1);
check_csr_wrrd("vsip", CSR_VSIP, (uint64_t) -1, 0x2);
check_csr_wrrd("vsie", CSR_VSIE, (uint64_t) -1, 0x222);
VERBOSE("setting all in mip\n");
CSRW(mip, (uint64_t)-1);
check_csr_rd("hip", CSR_HIP, 0x4);
check_csr_rd("sip", sip, 0x222);
// check_csr_rd_mask("mip", mip, 0x226, mtime_mask); // only test when nemu don't use difftest because spike, as ref, shut up time interrupt
check_csr_rd("vsip", CSR_VSIP, 0x2);
goto_priv(PRIV_VS);
check_csr_rd("sip (vs perspective)", sip, 0x2);
goto_priv(PRIV_M);
VERBOSE("clearing all in mip\n");
CSRW(mip, (uint64_t)0);
check_csr_rd("hip", CSR_HIP, 0x0);
check_csr_rd("sip", sip, 0x0);
// check_csr_rd_mask("mip", mip, 0x000, mtime_mask);
check_csr_rd("vsip", CSR_VSIP, 0x0);
goto_priv(PRIV_VS);
check_csr_rd("sip (vs perspective)", sip, 0x0);
goto_priv(PRIV_M);
VERBOSE("setting all in hvip\n");
CSRW(CSR_HVIP, (uint64_t)-1);
check_csr_rd("hvip", CSR_HVIP, 0x444);
check_csr_rd("hip", CSR_HIP, 0x444);
check_csr_rd("sip", sip, 0x0);
// check_csr_rd_mask("mip", mip, 0x444, mtime_mask);
check_csr_rd("vsip", CSR_VSIP, 0x222);
goto_priv(PRIV_VS);
check_csr_rd("sip (vs perspective)", sip, 0x222);
goto_priv(PRIV_M);
VERBOSE("clearing all in hvip\n");
CSRW(CSR_HVIP, (uint64_t)0);
check_csr_rd("hip", CSR_HIP, 0x0);
check_csr_rd("sip", sip, 0x0);
// check_csr_rd_mask("mip", mip, 0x000, mtime_mask);
check_csr_rd("vsip", CSR_VSIP, 0x0);
goto_priv(PRIV_VS);
check_csr_rd("sip (vs perspective)", sip, 0x0);
goto_priv(PRIV_M);
TEST_END();
}
bool interrupt_tests(){
TEST_START();
/**
* Test trigerring VSSI without delegating it.
* It assumes it is already delegated in miedeleg (it should be hardwired)
*/
goto_priv(PRIV_HS);
CSRC(sstatus, SSTATUS_SPIE_BIT | SSTATUS_SIE_BIT);
CSRS(CSR_HIE, 0x4);
CSRS(CSR_HIP, 0x4);
TEST_SETUP_EXCEPT();
goto_priv(PRIV_VS);
//CSRS(sstatus, SSTATUS_SIE_BIT);
TEST_ASSERT("vs sw irq with no delegation",
excpt.triggered && excpt.cause == CAUSE_VSSI && excpt.priv == PRIV_HS);
/**
* Test trigerring VSSI and delegating it. Should trap to VS with cause SSI.
* It assumes it is already delegated in miedeleg (it should be hardwired)
*/
goto_priv(PRIV_HS);
CSRS(CSR_HIDELEG, 0x4);
CSRS(CSR_HIP, 0x4);
TEST_SETUP_EXCEPT();
goto_priv(PRIV_VS);
CSRS(sie, 0x2);
CSRS(sstatus, 0x2);
TEST_ASSERT("vs sw irq with delegation",
excpt.triggered && excpt.cause == CAUSE_SSI && excpt.priv == PRIV_VS);
TEST_END();
}