#endif
"csrw "STR(CSR_MSTATUS)", %[mstatus]"
: [mstatus] "+&r" (__mstatus), [insn] "=&r" (val)
- : [mprv] "r" (MSTATUS_MPRV | MSTATUS_MXR), [addr] "r" (__mepc));
+ : [mprv] "r" (MSTATUS_MPRV|MSTATUS_MXR), [addr] "r" (__mepc));
#else
ulong rvc_mask = 3, tmp;
asm ("csrrs %[mstatus], "STR(CSR_MSTATUS)", %[mprv]\n"
"add %[insn], %[insn], %[tmp]\n"
"2: csrw "STR(CSR_MSTATUS)", %[mstatus]"
: [mstatus] "+&r" (__mstatus), [insn] "=&r" (val), [tmp] "=&r" (tmp)
- : [mprv] "r" (MSTATUS_MPRV | MSTATUS_MXR), [addr] "r" (__mepc),
+ : [mprv] "r" (MSTATUS_MPRV|MSTATUS_MXR), [addr] "r" (__mepc),
[rvc_mask] "r" (rvc_mask), [xlen_minus_16] "i" (__riscv_xlen - 16));
#endif
- *mstatus = __mstatus;
+ if (mstatus)
+ *mstatus = __mstatus;
return val;
}
struct sbi_trap_regs *regs,
struct sbi_scratch *scratch)
{
- ulong mstatus;
ulong insn = csr_read(mbadaddr);
if (unlikely((insn & 3) != 3)) {
- if (insn == 0) {
- mstatus = csr_read(CSR_MSTATUS);
- insn = get_insn(regs->mepc, &mstatus);
- }
+ if (insn == 0)
+ insn = get_insn(regs->mepc, NULL);
if ((insn & 3) != 3)
return truly_illegal_insn(insn, hartid, mcause,
regs, scratch);
struct sbi_scratch *scratch)
{
union reg_data val;
- ulong mstatus = csr_read(CSR_MSTATUS);
- ulong insn = get_insn(regs->mepc, &mstatus);
+ ulong insn = get_insn(regs->mepc, NULL);
ulong addr = csr_read(CSR_MTVAL);
int i, fp = 0, shift = 0, len = 0;
struct sbi_scratch *scratch)
{
union reg_data val;
- ulong mstatus = csr_read(CSR_MSTATUS);
- ulong insn = get_insn(regs->mepc, &mstatus);
+ ulong insn = get_insn(regs->mepc, NULL);
ulong addr = csr_read(CSR_MTVAL);
int i, len = 0;