X-Git-Url: https://git.libre-soc.org/?a=blobdiff_plain;f=isa%2Frv64sv%2Fillegal_vt_inst.S;h=de026f4c10d6ea02ac6faa2395e4eeff984fa714;hb=2f00c0c1f26a10f93f4a133bec69f4d0b95df685;hp=d0e5574ee19067306add40296b99e117602688cd;hpb=ddf8212714fcb6dc240a71bd1e1f52e02fc208b0;p=riscv-tests.git diff --git a/isa/rv64sv/illegal_vt_inst.S b/isa/rv64sv/illegal_vt_inst.S index d0e5574..de026f4 100644 --- a/isa/rv64sv/illegal_vt_inst.S +++ b/isa/rv64sv/illegal_vt_inst.S @@ -11,14 +11,16 @@ RVTEST_RV64S RVTEST_CODE_BEGIN - mfpcr a3,cr0 - li a4,1 - slli a5,a4,8 - or a3,a3,a4 # enable traps - mtpcr a3,cr0 + setpcr status, SR_EI # enable interrupt la a3,handler - mtpcr a3,cr3 # set exception handler + mtpcr a3,evec # set exception handler + + mfpcr a3,status + li a4,(1 << IRQ_COP) + slli a4,a4,SR_IM_SHIFT + or a3,a3,a4 # enable IM[COP] + mtpcr a3,status vsetcfg 32,0 li a3,4 @@ -48,12 +50,12 @@ handler: li x28,2 # check cause - mfpcr a3,cr6 - li a4,26 + vxcptcause a3 + li a4,HWACHA_CAUSE_VF_ILLEGAL_INSTRUCTION bne a3,a4,fail # check badvaddr - mfpcr a3,cr2 + vxcptaux a3 la a4,illegal bne a3,a4,fail