#***************************************************************************** # movz.S #----------------------------------------------------------------------------- # # Test movz instruction in a vf block. # #include "riscv_test.h" #include "test_macros.h" RVTEST_RV64U RVTEST_CODE_BEGIN vsetcfg 4,0 li a6,2048 vsetvl a6,a6 lui a0,%hi(vtcode) vf %lo(vtcode)(a0) la a7,dest vsd vx3,a7 fence li a1,0 li a2,-1 loop: ld a0,0(a7) slti a4,a1,10 slli a4,a4,63 srai a4,a4,63 xori a4,a4,-1 and a5,a2,a4 addi x28,a1,2 bne a0,a5,fail addi a7,a7,8 addi a1,a1,1 bne a1,a6,loop j pass vtcode: utidx x1 slti x2,x1,10 li x1,-1 li x3,0 movz x3,x2,x1 stop TEST_PASSFAIL RVTEST_CODE_END .data RVTEST_DATA_BEGIN TEST_DATA dest: .skip 16384 RVTEST_DATA_END