#***************************************************************************** # fmovn.S #----------------------------------------------------------------------------- # # Test fmovn instruction in a vf block. # #include "riscv_test.h" #include "test_macros.h" RVTEST_RV64UV RVTEST_CODE_BEGIN vsetcfg 4,2 li a6,2048 vsetvl a6,a6 lui a0,%hi(vtcode) vf %lo(vtcode)(a0) la a7,dest vfsd vf0,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 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 fmv.d.x f0,x3 fmv.d.x f1,x1 fmovn f0,x2,f1 stop TEST_PASSFAIL RVTEST_CODE_END .data RVTEST_DATA_BEGIN TEST_DATA dest: .skip 16384 RVTEST_DATA_END