Commit e71c2f7
fix(riscv/aia): imsic offset depends on number of guest files
Previously the implementation assumed a single guest interrupt file per
IMSIC. With this all interrupt files were contiguous in memory and
the offset between each hart's interrupt files' base was two pages
(s- and vs- level respectively). However, when the number of guest
interrupt files is larger than 1, this is not true. This patch removes
this assumption and calculates the size of each IMSIC memory address
range (and therefore, offset between each hart's IMSIC base address)
according to the layout mandated in the AIA spec version 1, which is
dependent on GEILEN.
Signed-off-by: Jose Martins <josemartins90@gmail.com>1 parent 7e661fb commit e71c2f7
6 files changed
Lines changed: 16 additions & 6 deletions
File tree
- scripts/arch/riscv
- src
- arch/riscv
- inc/arch
- irqc/aia
- inc
- platform/qemu-riscv64-virt
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
14 | 14 | | |
15 | 15 | | |
16 | 16 | | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
17 | 28 | | |
18 | 29 | | |
19 | 30 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
25 | 25 | | |
26 | 26 | | |
27 | 27 | | |
| 28 | + | |
28 | 29 | | |
29 | 30 | | |
30 | 31 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
45 | 45 | | |
46 | 46 | | |
47 | 47 | | |
48 | | - | |
| 48 | + | |
49 | 49 | | |
50 | 50 | | |
51 | 51 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
13 | | - | |
14 | | - | |
15 | | - | |
16 | 13 | | |
17 | 14 | | |
18 | 15 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
21 | 21 | | |
22 | 22 | | |
23 | 23 | | |
24 | | - | |
25 | | - | |
| 24 | + | |
| 25 | + | |
26 | 26 | | |
27 | 27 | | |
28 | 28 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
35 | 35 | | |
36 | 36 | | |
37 | 37 | | |
| 38 | + | |
38 | 39 | | |
39 | 40 | | |
40 | 41 | | |
| |||
0 commit comments