include: sbi: Add mtinst/htinst psuedoinstructions
Add psuedoinstruction encodings written to mtinst/htinst for faults caused by implicit memory access for VS-stage address translation Signed-off-by: dramforever <dramforever@live.com> Reviewed-by: Anup Patel <anup@brainfault.org>
This commit is contained in:
parent
9dc5ec5c51
commit
551c70c040
|
@ -841,6 +841,26 @@
|
||||||
#define INSN_MASK_FENCE_TSO 0xffffffff
|
#define INSN_MASK_FENCE_TSO 0xffffffff
|
||||||
#define INSN_MATCH_FENCE_TSO 0x8330000f
|
#define INSN_MATCH_FENCE_TSO 0x8330000f
|
||||||
|
|
||||||
|
#if __riscv_xlen == 64
|
||||||
|
|
||||||
|
/* 64-bit read for VS-stage address translation (RV64) */
|
||||||
|
#define INSN_PSEUDO_VS_LOAD 0x00003000
|
||||||
|
|
||||||
|
/* 64-bit write for VS-stage address translation (RV64) */
|
||||||
|
#define INSN_PSEUDO_VS_STORE 0x00003020
|
||||||
|
|
||||||
|
#elif __riscv_xlen == 32
|
||||||
|
|
||||||
|
/* 32-bit read for VS-stage address translation (RV32) */
|
||||||
|
#define INSN_PSEUDO_VS_LOAD 0x00002000
|
||||||
|
|
||||||
|
/* 32-bit write for VS-stage address translation (RV32) */
|
||||||
|
#define INSN_PSEUDO_VS_STORE 0x00002020
|
||||||
|
|
||||||
|
#else
|
||||||
|
#error "Unexpected __riscv_xlen"
|
||||||
|
#endif
|
||||||
|
|
||||||
#define INSN_16BIT_MASK 0x3
|
#define INSN_16BIT_MASK 0x3
|
||||||
#define INSN_32BIT_MASK 0x1c
|
#define INSN_32BIT_MASK 0x1c
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue