mirror of
https://github.com/SpinalHDL/VexRiscv.git
synced 2025-01-03 03:43:39 -05:00
PMP passes test with GenZephyr, but pipeline flushes have been disabled
This commit is contained in:
parent
987de8fb6a
commit
5cb5061d9b
9 changed files with 197 additions and 204 deletions
|
@ -5,11 +5,12 @@ import vexriscv.ip.{DataCacheConfig, InstructionCacheConfig}
|
|||
import vexriscv.{plugin, VexRiscv, VexRiscvConfig}
|
||||
import spinal.core._
|
||||
|
||||
object GenZephyr extends App{
|
||||
object GenZephyr extends App {
|
||||
def cpu() = new VexRiscv(
|
||||
config = VexRiscvConfig(
|
||||
plugins = List(
|
||||
new IBusCachedPlugin(
|
||||
resetVector = 0x80000000l,
|
||||
prediction = STATIC,
|
||||
config = InstructionCacheConfig(
|
||||
cacheSize = 4096,
|
||||
|
|
|
@ -153,8 +153,8 @@ class PmpPlugin(regions : Int, ioRange : UInt => Bool) extends Plugin[VexRiscv]
|
|||
pmps += PmpRegister()
|
||||
csrService.rw(0x3b0 + i, pmps(i).csr.addr)
|
||||
csrService.onWrite(0x3b0 + i) {
|
||||
execute.arbitration.flushNext := True
|
||||
redoInterface.valid := True
|
||||
//execute.arbitration.flushNext := True
|
||||
//redoInterface.valid := True
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -173,8 +173,8 @@ class PmpPlugin(regions : Int, ioRange : UInt => Bool) extends Plugin[VexRiscv]
|
|||
1 -> pmps((i * 4) ).csr.w, 0 -> pmps((i * 4) ).csr.r
|
||||
)
|
||||
csrService.onWrite(0x3a0 + i) {
|
||||
execute.arbitration.flushNext := True
|
||||
redoInterface.valid := True
|
||||
//execute.arbitration.flushNext := True
|
||||
//redoInterface.valid := True
|
||||
}
|
||||
}
|
||||
|
||||
|
|
3
src/test/cpp/raw/pmp/.gdbinit
Normal file
3
src/test/cpp/raw/pmp/.gdbinit
Normal file
|
@ -0,0 +1,3 @@
|
|||
target remote localhost:3333
|
||||
monitor reset halt
|
||||
load
|
|
@ -8,163 +8,159 @@ Disassembly of section .crt_section:
|
|||
80000000: 00000097 auipc ra,0x0
|
||||
80000004: 01008093 addi ra,ra,16 # 80000010 <trap>
|
||||
80000008: 30509073 csrw mtvec,ra
|
||||
8000000c: 0240006f j 80000030 <test0>
|
||||
8000000c: 00c0006f j 80000018 <test0>
|
||||
|
||||
80000010 <trap>:
|
||||
80000010: 341f1073 csrw mepc,t5
|
||||
80000014: 30200073 mret
|
||||
|
||||
80000018 <to_user>:
|
||||
80000018: 00014137 lui sp,0x14
|
||||
8000001c: 30013073 csrc mstatus,sp
|
||||
80000020: 20000113 li sp,512
|
||||
80000024: 30012073 csrs mstatus,sp
|
||||
80000028: 341e9073 csrw mepc,t4
|
||||
8000002c: 30200073 mret
|
||||
|
||||
80000030 <test0>:
|
||||
80000030: 00000e13 li t3,0
|
||||
80000034: 00000f17 auipc t5,0x0
|
||||
80000038: 1f0f0f13 addi t5,t5,496 # 80000224 <fail>
|
||||
8000003c: 800000b7 lui ra,0x80000
|
||||
80000040: 80008237 lui tp,0x80008
|
||||
80000044: deadc137 lui sp,0xdeadc
|
||||
80000048: eef10113 addi sp,sp,-273 # deadbeef <pass+0x5eadbcbf>
|
||||
8000004c: 0020a023 sw sp,0(ra) # 80000000 <pass+0xfffffdd0>
|
||||
80000050: 00222023 sw sp,0(tp) # 80008000 <pass+0x7dd0>
|
||||
80000054: 0000a183 lw gp,0(ra)
|
||||
80000058: 1c311663 bne sp,gp,80000224 <fail>
|
||||
8000005c: 00022183 lw gp,0(tp) # 0 <_start-0x80000000>
|
||||
80000060: 1c311263 bne sp,gp,80000224 <fail>
|
||||
80000064: 071a12b7 lui t0,0x71a1
|
||||
80000068: 80828293 addi t0,t0,-2040 # 71a0808 <_start-0x78e5f7f8>
|
||||
8000006c: 3a029073 csrw pmpcfg0,t0
|
||||
80000070: 191c02b7 lui t0,0x191c0
|
||||
80000074: 50428293 addi t0,t0,1284 # 191c0504 <_start-0x66e3fafc>
|
||||
80000078: 3a129073 csrw pmpcfg1,t0
|
||||
8000007c: 01800293 li t0,24
|
||||
80000080: 3a229073 csrw pmpcfg2,t0
|
||||
80000084: 0f1e22b7 lui t0,0xf1e2
|
||||
80000088: 90028293 addi t0,t0,-1792 # f1e1900 <_start-0x70e1e700>
|
||||
8000008c: 3a329073 csrw pmpcfg3,t0
|
||||
80000090: 200002b7 lui t0,0x20000
|
||||
80000094: 3b029073 csrw pmpaddr0,t0
|
||||
80000098: fff00293 li t0,-1
|
||||
8000009c: 3b129073 csrw pmpaddr1,t0
|
||||
800000a0: 200022b7 lui t0,0x20002
|
||||
800000a4: 3b229073 csrw pmpaddr2,t0
|
||||
80000018 <test0>:
|
||||
80000018: 00000e13 li t3,0
|
||||
8000001c: 00000f17 auipc t5,0x0
|
||||
80000020: 1f4f0f13 addi t5,t5,500 # 80000210 <fail>
|
||||
80000024: 800000b7 lui ra,0x80000
|
||||
80000028: 80008237 lui tp,0x80008
|
||||
8000002c: deadc137 lui sp,0xdeadc
|
||||
80000030: eef10113 addi sp,sp,-273 # deadbeef <pass+0x5eadbcd3>
|
||||
80000034: 0020a023 sw sp,0(ra) # 80000000 <pass+0xfffffde4>
|
||||
80000038: 00222023 sw sp,0(tp) # 80008000 <pass+0x7de4>
|
||||
8000003c: 0000a183 lw gp,0(ra)
|
||||
80000040: 1c311863 bne sp,gp,80000210 <fail>
|
||||
80000044: 00022183 lw gp,0(tp) # 0 <_start-0x80000000>
|
||||
80000048: 1c311463 bne sp,gp,80000210 <fail>
|
||||
8000004c: 071212b7 lui t0,0x7121
|
||||
80000050: 80828293 addi t0,t0,-2040 # 7120808 <_start-0x78edf7f8>
|
||||
80000054: 3a029073 csrw pmpcfg0,t0
|
||||
80000058: 191f02b7 lui t0,0x191f0
|
||||
8000005c: 30428293 addi t0,t0,772 # 191f0304 <_start-0x66e0fcfc>
|
||||
80000060: 3a129073 csrw pmpcfg1,t0
|
||||
80000064: 01800293 li t0,24
|
||||
80000068: 3a229073 csrw pmpcfg2,t0
|
||||
8000006c: 0f1e22b7 lui t0,0xf1e2
|
||||
80000070: 90028293 addi t0,t0,-1792 # f1e1900 <_start-0x70e1e700>
|
||||
80000074: 3a329073 csrw pmpcfg3,t0
|
||||
80000078: 200002b7 lui t0,0x20000
|
||||
8000007c: 3b029073 csrw pmpaddr0,t0
|
||||
80000080: fff00293 li t0,-1
|
||||
80000084: 3b129073 csrw pmpaddr1,t0
|
||||
80000088: 200022b7 lui t0,0x20002
|
||||
8000008c: 3b229073 csrw pmpaddr2,t0
|
||||
80000090: 200042b7 lui t0,0x20004
|
||||
80000094: fff28293 addi t0,t0,-1 # 20003fff <_start-0x5fffc001>
|
||||
80000098: 3b329073 csrw pmpaddr3,t0
|
||||
8000009c: 200042b7 lui t0,0x20004
|
||||
800000a0: fff28293 addi t0,t0,-1 # 20003fff <_start-0x5fffc001>
|
||||
800000a4: 3b429073 csrw pmpaddr4,t0
|
||||
800000a8: 200042b7 lui t0,0x20004
|
||||
800000ac: fff28293 addi t0,t0,-1 # 20003fff <_start-0x5fffc001>
|
||||
800000b0: 3b329073 csrw pmpaddr3,t0
|
||||
800000b4: 200042b7 lui t0,0x20004
|
||||
800000b8: fff28293 addi t0,t0,-1 # 20003fff <_start-0x5fffc001>
|
||||
800000bc: 3b429073 csrw pmpaddr4,t0
|
||||
800000b0: 3b529073 csrw pmpaddr5,t0
|
||||
800000b4: 200022b7 lui t0,0x20002
|
||||
800000b8: fff28293 addi t0,t0,-1 # 20001fff <_start-0x5fffe001>
|
||||
800000bc: 3b629073 csrw pmpaddr6,t0
|
||||
800000c0: 200042b7 lui t0,0x20004
|
||||
800000c4: fff28293 addi t0,t0,-1 # 20003fff <_start-0x5fffc001>
|
||||
800000c8: 3b529073 csrw pmpaddr5,t0
|
||||
800000cc: 200022b7 lui t0,0x20002
|
||||
800000d0: fff28293 addi t0,t0,-1 # 20001fff <_start-0x5fffe001>
|
||||
800000d4: 3b629073 csrw pmpaddr6,t0
|
||||
800000d8: 200042b7 lui t0,0x20004
|
||||
800000dc: fff28293 addi t0,t0,-1 # 20003fff <_start-0x5fffc001>
|
||||
800000e0: 3b729073 csrw pmpaddr7,t0
|
||||
800000e4: 200042b7 lui t0,0x20004
|
||||
800000e8: fff28293 addi t0,t0,-1 # 20003fff <_start-0x5fffc001>
|
||||
800000ec: 3b829073 csrw pmpaddr8,t0
|
||||
800000c8: 3b729073 csrw pmpaddr7,t0
|
||||
800000cc: 200042b7 lui t0,0x20004
|
||||
800000d0: fff28293 addi t0,t0,-1 # 20003fff <_start-0x5fffc001>
|
||||
800000d4: 3b829073 csrw pmpaddr8,t0
|
||||
800000d8: 00000293 li t0,0
|
||||
800000dc: 3b929073 csrw pmpaddr9,t0
|
||||
800000e0: 00000293 li t0,0
|
||||
800000e4: 3ba29073 csrw pmpaddr10,t0
|
||||
800000e8: 00000293 li t0,0
|
||||
800000ec: 3bb29073 csrw pmpaddr11,t0
|
||||
800000f0: 00000293 li t0,0
|
||||
800000f4: 3b929073 csrw pmpaddr9,t0
|
||||
800000f4: 3bc29073 csrw pmpaddr12,t0
|
||||
800000f8: 00000293 li t0,0
|
||||
800000fc: 3ba29073 csrw pmpaddr10,t0
|
||||
800000fc: 3bd29073 csrw pmpaddr13,t0
|
||||
80000100: 00000293 li t0,0
|
||||
80000104: 3bb29073 csrw pmpaddr11,t0
|
||||
80000104: 3be29073 csrw pmpaddr14,t0
|
||||
80000108: 00000293 li t0,0
|
||||
8000010c: 3bc29073 csrw pmpaddr12,t0
|
||||
80000110: 00000293 li t0,0
|
||||
80000114: 3bd29073 csrw pmpaddr13,t0
|
||||
80000118: 00000293 li t0,0
|
||||
8000011c: 3be29073 csrw pmpaddr14,t0
|
||||
80000120: 00000293 li t0,0
|
||||
80000124: 3bf29073 csrw pmpaddr15,t0
|
||||
80000128: 00c10137 lui sp,0xc10
|
||||
8000012c: fee10113 addi sp,sp,-18 # c0ffee <_start-0x7f3f0012>
|
||||
80000130: 0020a023 sw sp,0(ra)
|
||||
80000134: 00222023 sw sp,0(tp) # 0 <_start-0x80000000>
|
||||
80000138: 0000a183 lw gp,0(ra)
|
||||
8000013c: 0e311463 bne sp,gp,80000224 <fail>
|
||||
80000140: 00022183 lw gp,0(tp) # 0 <_start-0x80000000>
|
||||
80000144: 0e311063 bne sp,gp,80000224 <fail>
|
||||
8000010c: 3bf29073 csrw pmpaddr15,t0
|
||||
80000110: 00c10137 lui sp,0xc10
|
||||
80000114: fee10113 addi sp,sp,-18 # c0ffee <_start-0x7f3f0012>
|
||||
80000118: 0020a023 sw sp,0(ra)
|
||||
8000011c: 00222023 sw sp,0(tp) # 0 <_start-0x80000000>
|
||||
80000120: 0000a183 lw gp,0(ra)
|
||||
80000124: 0e311663 bne sp,gp,80000210 <fail>
|
||||
80000128: 00000193 li gp,0
|
||||
8000012c: 00022183 lw gp,0(tp) # 0 <_start-0x80000000>
|
||||
80000130: 0e311063 bne sp,gp,80000210 <fail>
|
||||
|
||||
80000148 <test1>:
|
||||
80000148: 00100e13 li t3,1
|
||||
8000014c: 00000f17 auipc t5,0x0
|
||||
80000150: 0d8f0f13 addi t5,t5,216 # 80000224 <fail>
|
||||
80000154: 079a12b7 lui t0,0x79a1
|
||||
80000158: 80828293 addi t0,t0,-2040 # 79a0808 <_start-0x7865f7f8>
|
||||
8000015c: 3a029073 csrw pmpcfg0,t0
|
||||
80000160: deadc137 lui sp,0xdeadc
|
||||
80000164: eef10113 addi sp,sp,-273 # deadbeef <pass+0x5eadbcbf>
|
||||
80000168: 00222023 sw sp,0(tp) # 0 <_start-0x80000000>
|
||||
80000134 <test1>:
|
||||
80000134: 00100e13 li t3,1
|
||||
80000138: 00000f17 auipc t5,0x0
|
||||
8000013c: 0d8f0f13 addi t5,t5,216 # 80000210 <fail>
|
||||
80000140: 079212b7 lui t0,0x7921
|
||||
80000144: 80828293 addi t0,t0,-2040 # 7920808 <_start-0x786df7f8>
|
||||
80000148: 3a029073 csrw pmpcfg0,t0
|
||||
8000014c: deadc137 lui sp,0xdeadc
|
||||
80000150: eef10113 addi sp,sp,-273 # deadbeef <pass+0x5eadbcd3>
|
||||
80000154: 00222023 sw sp,0(tp) # 0 <_start-0x80000000>
|
||||
80000158: 00000f17 auipc t5,0x0
|
||||
8000015c: 010f0f13 addi t5,t5,16 # 80000168 <test2>
|
||||
80000160: 00022183 lw gp,0(tp) # 0 <_start-0x80000000>
|
||||
80000164: 0ac0006f j 80000210 <fail>
|
||||
|
||||
80000168 <test2>:
|
||||
80000168: 00200e13 li t3,2
|
||||
8000016c: 00000f17 auipc t5,0x0
|
||||
80000170: 010f0f13 addi t5,t5,16 # 8000017c <test2>
|
||||
80000174: 00022183 lw gp,0(tp) # 0 <_start-0x80000000>
|
||||
80000178: 0ac0006f j 80000224 <fail>
|
||||
80000170: 0a4f0f13 addi t5,t5,164 # 80000210 <fail>
|
||||
80000174: 071212b7 lui t0,0x7121
|
||||
80000178: 80828293 addi t0,t0,-2040 # 7120808 <_start-0x78edf7f8>
|
||||
8000017c: 3a029073 csrw pmpcfg0,t0
|
||||
80000180: deadc137 lui sp,0xdeadc
|
||||
80000184: eef10113 addi sp,sp,-273 # deadbeef <pass+0x5eadbcd3>
|
||||
80000188: 00222023 sw sp,0(tp) # 0 <_start-0x80000000>
|
||||
8000018c: 00000f17 auipc t5,0x0
|
||||
80000190: 010f0f13 addi t5,t5,16 # 8000019c <test3>
|
||||
80000194: 00022183 lw gp,0(tp) # 0 <_start-0x80000000>
|
||||
80000198: 0780006f j 80000210 <fail>
|
||||
|
||||
8000017c <test2>:
|
||||
8000017c: 00200e13 li t3,2
|
||||
80000180: 00000f17 auipc t5,0x0
|
||||
80000184: 0a4f0f13 addi t5,t5,164 # 80000224 <fail>
|
||||
80000188: 071a12b7 lui t0,0x71a1
|
||||
8000018c: 80828293 addi t0,t0,-2040 # 71a0808 <_start-0x78e5f7f8>
|
||||
80000190: 3a029073 csrw pmpcfg0,t0
|
||||
80000194: deadc137 lui sp,0xdeadc
|
||||
80000198: eef10113 addi sp,sp,-273 # deadbeef <pass+0x5eadbcbf>
|
||||
8000019c: 00222023 sw sp,0(tp) # 0 <_start-0x80000000>
|
||||
8000019c <test3>:
|
||||
8000019c: 00300e13 li t3,3
|
||||
800001a0: 00000f17 auipc t5,0x0
|
||||
800001a4: 010f0f13 addi t5,t5,16 # 800001b0 <test3>
|
||||
800001a8: 00022183 lw gp,0(tp) # 0 <_start-0x80000000>
|
||||
800001ac: 0780006f j 80000224 <fail>
|
||||
800001a4: 070f0f13 addi t5,t5,112 # 80000210 <fail>
|
||||
800001a8: 00000117 auipc sp,0x0
|
||||
800001ac: 01010113 addi sp,sp,16 # 800001b8 <test4>
|
||||
800001b0: 34111073 csrw mepc,sp
|
||||
800001b4: 30200073 mret
|
||||
|
||||
800001b0 <test3>:
|
||||
800001b0: 00300e13 li t3,3
|
||||
800001b4: 00000f17 auipc t5,0x0
|
||||
800001b8: 070f0f13 addi t5,t5,112 # 80000224 <fail>
|
||||
800001bc: 00000e97 auipc t4,0x0
|
||||
800001c0: 00ce8e93 addi t4,t4,12 # 800001c8 <test4>
|
||||
800001c4: e55ff06f j 80000018 <to_user>
|
||||
800001b8 <test4>:
|
||||
800001b8: 00400e13 li t3,4
|
||||
800001bc: 00000f17 auipc t5,0x0
|
||||
800001c0: 054f0f13 addi t5,t5,84 # 80000210 <fail>
|
||||
800001c4: deadc137 lui sp,0xdeadc
|
||||
800001c8: eef10113 addi sp,sp,-273 # deadbeef <pass+0x5eadbcd3>
|
||||
800001cc: 00222023 sw sp,0(tp) # 0 <_start-0x80000000>
|
||||
800001d0: 00000f17 auipc t5,0x0
|
||||
800001d4: 010f0f13 addi t5,t5,16 # 800001e0 <test5>
|
||||
800001d8: 00022183 lw gp,0(tp) # 0 <_start-0x80000000>
|
||||
800001dc: 0340006f j 80000210 <fail>
|
||||
|
||||
800001c8 <test4>:
|
||||
800001c8: 00400e13 li t3,4
|
||||
800001cc: 00000f17 auipc t5,0x0
|
||||
800001d0: 058f0f13 addi t5,t5,88 # 80000224 <fail>
|
||||
800001d4: deadc137 lui sp,0xdeadc
|
||||
800001d8: eef10113 addi sp,sp,-273 # deadbeef <pass+0x5eadbcbf>
|
||||
800001dc: 00222023 sw sp,0(tp) # 0 <_start-0x80000000>
|
||||
800001e0: 00000f17 auipc t5,0x0
|
||||
800001e4: 010f0f13 addi t5,t5,16 # 800001f0 <test5>
|
||||
800001e8: 00022183 lw gp,0(tp) # 0 <_start-0x80000000>
|
||||
800001ec: 0380006f j 80000224 <fail>
|
||||
800001e0 <test5>:
|
||||
800001e0: 00500e13 li t3,5
|
||||
800001e4: deadc137 lui sp,0xdeadc
|
||||
800001e8: eef10113 addi sp,sp,-273 # deadbeef <pass+0x5eadbcd3>
|
||||
800001ec: 0020a023 sw sp,0(ra)
|
||||
800001f0: 0000a183 lw gp,0(ra)
|
||||
800001f4: 00311e63 bne sp,gp,80000210 <fail>
|
||||
|
||||
800001f0 <test5>:
|
||||
800001f0: 00500e13 li t3,5
|
||||
800001f4: 00000f17 auipc t5,0x0
|
||||
800001f8: 03cf0f13 addi t5,t5,60 # 80000230 <pass>
|
||||
800001f8 <test6>:
|
||||
800001f8: 00600e13 li t3,6
|
||||
800001fc: 80010237 lui tp,0x80010
|
||||
80000200: deadc137 lui sp,0xdeadc
|
||||
80000204: eef10113 addi sp,sp,-273 # deadbeef <pass+0x5eadbcbf>
|
||||
80000208: 0020a023 sw sp,0(ra)
|
||||
8000020c: 0000a183 lw gp,0(ra)
|
||||
80000210: 00311a63 bne sp,gp,80000224 <fail>
|
||||
80000214: 00022183 lw gp,0(tp) # 80010000 <pass+0xfdd0>
|
||||
80000218: 00000f17 auipc t5,0x0
|
||||
8000021c: 018f0f13 addi t5,t5,24 # 80000230 <pass>
|
||||
80000220: 00322023 sw gp,0(tp) # 0 <_start-0x80000000>
|
||||
80000200: 00022183 lw gp,0(tp) # 80010000 <pass+0xfde4>
|
||||
80000204: 00000f17 auipc t5,0x0
|
||||
80000208: 018f0f13 addi t5,t5,24 # 8000021c <pass>
|
||||
8000020c: 00322023 sw gp,0(tp) # 0 <_start-0x80000000>
|
||||
|
||||
80000224 <fail>:
|
||||
80000224: f0100137 lui sp,0xf0100
|
||||
80000228: f2410113 addi sp,sp,-220 # f00fff24 <pass+0x700ffcf4>
|
||||
8000022c: 01c12023 sw t3,0(sp)
|
||||
80000210 <fail>:
|
||||
80000210: f0100137 lui sp,0xf0100
|
||||
80000214: f2410113 addi sp,sp,-220 # f00fff24 <pass+0x700ffd08>
|
||||
80000218: 01c12023 sw t3,0(sp)
|
||||
|
||||
80000230 <pass>:
|
||||
80000230: f0100137 lui sp,0xf0100
|
||||
80000234: f2010113 addi sp,sp,-224 # f00fff20 <pass+0x700ffcf0>
|
||||
80000238: 00012023 sw zero,0(sp)
|
||||
8000021c <pass>:
|
||||
8000021c: 29a00e13 li t3,666
|
||||
80000220: f0100137 lui sp,0xf0100
|
||||
80000224: f2010113 addi sp,sp,-224 # f00fff20 <pass+0x700ffd04>
|
||||
80000228: 00012023 sw zero,0(sp)
|
||||
|
|
Binary file not shown.
|
@ -1,39 +1,38 @@
|
|||
:0200000480007A
|
||||
:100000009700000093800001739050306F00400211
|
||||
:1000100073101F34730020303741010073300130FA
|
||||
:10002000130100207320013073901E3473002030C0
|
||||
:10003000130E0000170F0000130F0F1FB7000080F2
|
||||
:100040003782008037C1ADDE1301F1EE23A020001E
|
||||
:100050002320220083A100006316311C83210200AB
|
||||
:100060006312311CB7121A07938282807390023A8E
|
||||
:10007000B7021C19938242507390123A9302800186
|
||||
:100080007390223AB7221E0F938202907390323AF5
|
||||
:10009000B70200207390023B9302F0FF7390123B73
|
||||
:1000A000B72200207390223BB74200209382F2FFD8
|
||||
:1000B0007390323BB74200209382F2FF7390423B31
|
||||
:1000C000B74200209382F2FF7390523BB722002088
|
||||
:1000D0009382F2FF7390623BB74200209382F2FF5B
|
||||
:1000E0007390723BB74200209382F2FF7390823B81
|
||||
:1000F000930200007390923B930200007390A23B26
|
||||
:10010000930200007390B23B930200007390C23BD5
|
||||
:10011000930200007390D23B930200007390E23B85
|
||||
:10012000930200007390F23B3701C1001301E1FE1E
|
||||
:1001300023A020002320220083A100006314310E9D
|
||||
:10014000832102006310310E130E1000170F000000
|
||||
:10015000130F8F0DB7129A07938282807390023A21
|
||||
:1001600037C1ADDE1301F1EE23202200170F00008E
|
||||
:10017000130F0F01832102006F00C00A130E20002D
|
||||
:10018000170F0000130F4F0AB7121A0793828280CD
|
||||
:100190007390023A37C1ADDE1301F1EE2320220045
|
||||
:1001A000170F0000130F0F01832102006F0080075B
|
||||
:1001B000130E3000170F0000130F0F07970E0000EB
|
||||
:1001C000938ECE006FF05FE5130E4000170F000016
|
||||
:1001D000130F8F0537C1ADDE1301F1EE232022008E
|
||||
:1001E000170F0000130F0F01832102006F0080031F
|
||||
:1001F000130E5000170F0000130FCF0337020180BA
|
||||
:1002000037C1ADDE1301F1EE23A0200083A1000071
|
||||
:10021000631A310083210200170F0000130F8F01B2
|
||||
:1002200023203200370110F0130141F22320C101D5
|
||||
:0C023000370110F0130101F2232001003F
|
||||
:100000009700000093800001739050306F00C00093
|
||||
:1000100073101F3473002030130E0000170F000000
|
||||
:10002000130F4F1FB70000803782008037C1ADDE4D
|
||||
:100030001301F1EE23A020002320220083A1000061
|
||||
:100040006318311C832102006314311CB71212079C
|
||||
:10005000938282807390023AB7021F1993824230D2
|
||||
:100060007390123A930280017390223AB7221E0FC6
|
||||
:10007000938202907390323AB70200207390023B51
|
||||
:100080009302F0FF7390123BB72200207390223B43
|
||||
:10009000B74200209382F2FF7390323BB7420020B8
|
||||
:1000A0009382F2FF7390423BB74200209382F2FFAB
|
||||
:1000B0007390523BB72200209382F2FF7390623B11
|
||||
:1000C000B74200209382F2FF7390723BB742002048
|
||||
:1000D0009382F2FF7390823B930200007390923BF5
|
||||
:1000E000930200007390A23B930200007390B23B16
|
||||
:1000F000930200007390C23B930200007390D23BC6
|
||||
:10010000930200007390E23B930200007390F23B75
|
||||
:100110003701C1001301E1FE23A0200023202200AB
|
||||
:1001200083A100006316310E9301000083210200B9
|
||||
:100130006310310E130E1000170F0000130F8F0DF8
|
||||
:10014000B7129207938282807390023A37C1ADDE74
|
||||
:100150001301F1EE23202200170F0000130F0F01EF
|
||||
:10016000832102006F00C00A130E2000170F000049
|
||||
:10017000130F4F0AB7121207938282807390023ACC
|
||||
:1001800037C1ADDE1301F1EE23202200170F00006E
|
||||
:10019000130F0F01832102006F008007130E300040
|
||||
:1001A000170F0000130F0F071701000013010101C3
|
||||
:1001B0007310113473002030130E4000170F00002D
|
||||
:1001C000130F4F0537C1ADDE1301F1EE23202200DE
|
||||
:1001D000170F0000130F0F01832102006F0040036F
|
||||
:1001E000130E500037C1ADDE1301F1EE23A0200045
|
||||
:1001F00083A10000631E3100130E600037020180EE
|
||||
:1002000083210200170F0000130F8F0123203200FB
|
||||
:10021000370110F0130141F22320C101130EA02970
|
||||
:0C022000370110F0130101F2232001004F
|
||||
:040000058000000077
|
||||
:00000001FF
|
||||
|
|
|
@ -15,20 +15,19 @@ LOAD /opt/riscv/lib/gcc/riscv64-unknown-elf/10.2.0/../../../../riscv64-unknown-e
|
|||
END GROUP
|
||||
LOAD /opt/riscv/lib/gcc/riscv64-unknown-elf/10.2.0/libgcc.a
|
||||
|
||||
.crt_section 0x0000000080000000 0x23c
|
||||
.crt_section 0x0000000080000000 0x22c
|
||||
0x0000000080000000 . = ALIGN (0x4)
|
||||
*crt.o(.text)
|
||||
.text 0x0000000080000000 0x23c build/src/crt.o
|
||||
.text 0x0000000080000000 0x22c build/src/crt.o
|
||||
0x0000000080000000 _start
|
||||
0x0000000080000010 trap
|
||||
0x0000000080000018 to_user
|
||||
OUTPUT(build/pmp.elf elf32-littleriscv)
|
||||
|
||||
.data 0x000000008000023c 0x0
|
||||
.data 0x000000008000023c 0x0 build/src/crt.o
|
||||
.data 0x000000008000022c 0x0
|
||||
.data 0x000000008000022c 0x0 build/src/crt.o
|
||||
|
||||
.bss 0x000000008000023c 0x0
|
||||
.bss 0x000000008000023c 0x0 build/src/crt.o
|
||||
.bss 0x000000008000022c 0x0
|
||||
.bss 0x000000008000022c 0x0 build/src/crt.o
|
||||
|
||||
.riscv.attributes
|
||||
0x0000000000000000 0x1e
|
||||
|
|
|
@ -5,12 +5,11 @@
|
|||
*/
|
||||
|
||||
#define TEST_ID x28
|
||||
#define USER_RA x29
|
||||
#define TRAP_RA x30
|
||||
|
||||
#define PMPCFG0 0x071a0808
|
||||
#define PMPCFG0_ 0x079a0808 // lock region 2
|
||||
#define PMPCFG1 0x191c0504
|
||||
#define PMPCFG0 0x07120808
|
||||
#define PMPCFG0_ 0x07920808 // lock region 2
|
||||
#define PMPCFG1 0x191f0304
|
||||
#define PMPCFG2 0x00000018
|
||||
#define PMPCFG3 0x0f1e1900
|
||||
|
||||
|
@ -42,15 +41,6 @@ trap:
|
|||
csrw mepc, TRAP_RA
|
||||
mret
|
||||
|
||||
.global to_user
|
||||
to_user:
|
||||
li x2, 0x14000
|
||||
csrc mstatus, x2
|
||||
li x2, 0x200
|
||||
csrs mstatus, x2
|
||||
csrw mepc, USER_RA
|
||||
mret
|
||||
|
||||
// configure PMP, attempt read/write from machine mode
|
||||
test0:
|
||||
li TEST_ID, 0
|
||||
|
@ -112,6 +102,7 @@ test0:
|
|||
sw x2, 0x0(x4)
|
||||
lw x3, 0x0(x1)
|
||||
bne x2, x3, fail
|
||||
li x3, 0x0
|
||||
lw x3, 0x0(x4)
|
||||
bne x2, x3, fail
|
||||
|
||||
|
@ -143,8 +134,9 @@ test2:
|
|||
test3:
|
||||
li TEST_ID, 3
|
||||
la TRAP_RA, fail
|
||||
la USER_RA, test4
|
||||
j to_user
|
||||
la x2, test4
|
||||
csrw mepc, x2
|
||||
mret
|
||||
|
||||
// attempt to read/write region 2 from user mode
|
||||
test4:
|
||||
|
@ -159,12 +151,14 @@ test4:
|
|||
// attempt to read/write other regions from user mode
|
||||
test5:
|
||||
li TEST_ID, 5
|
||||
la TRAP_RA, pass
|
||||
li x4, 0x80010000
|
||||
li x2, 0xdeadbeef
|
||||
sw x2, 0x0(x1)
|
||||
lw x3, 0x0(x1)
|
||||
bne x2, x3, fail // should be OK
|
||||
bne x2, x3, fail // should be OK (read/write 0x80000000)
|
||||
|
||||
test6:
|
||||
li TEST_ID, 6
|
||||
li x4, 0x80010000
|
||||
lw x3, 0x0(x4) // should be OK (read 0x80010000)
|
||||
la TRAP_RA, pass
|
||||
sw x3, 0x0(x4) // should fault (write 0x80010000)
|
||||
|
@ -174,5 +168,6 @@ fail:
|
|||
sw TEST_ID, 0(x2)
|
||||
|
||||
pass:
|
||||
li TEST_ID, 666
|
||||
li x2, 0xf00fff20
|
||||
sw x0, 0(x2)
|
||||
|
|
|
@ -4054,7 +4054,7 @@ int main(int argc, char **argv, char **env) {
|
|||
#endif
|
||||
|
||||
#ifdef PMP
|
||||
redo(REDO,WorkspaceRegression("pmp").withRiscvRef()->loadHex(string(REGRESSION_PATH) + "../raw/pmp/build/pmp.hex")->bootAt(0x00000000u)->run(10e3););
|
||||
redo(REDO,WorkspaceRegression("pmp").loadHex(string(REGRESSION_PATH) + "../raw/pmp/build/pmp.hex")->bootAt(0x00000000u)->run(10e3););
|
||||
#endif
|
||||
|
||||
#ifdef AMO
|
||||
|
|
Loading…
Reference in a new issue