112771Sqtt2@cornell.edu# See LICENSE for license details.
212771Sqtt2@cornell.edu
312771Sqtt2@cornell.edu#*****************************************************************************
412771Sqtt2@cornell.edu# move.S
512771Sqtt2@cornell.edu#-----------------------------------------------------------------------------
612771Sqtt2@cornell.edu#
712771Sqtt2@cornell.edu# This test verifies that the fmv.s.x, fmv.x.s, and fsgnj[x|n].d instructions
812771Sqtt2@cornell.edu# and the fcsr work properly.
912771Sqtt2@cornell.edu#
1012771Sqtt2@cornell.edu
1112771Sqtt2@cornell.edu#include "riscv_test.h"
1212771Sqtt2@cornell.edu#include "test_macros.h"
1312771Sqtt2@cornell.edu
1412771Sqtt2@cornell.eduRVTEST_RV64UF
1512771Sqtt2@cornell.eduRVTEST_CODE_BEGIN
1612771Sqtt2@cornell.edu
1712771Sqtt2@cornell.edu  TEST_CASE(2, a1, 1, csrwi fcsr, 1; li a0, 0x1234; fssr a1, a0)
1812771Sqtt2@cornell.edu  TEST_CASE(3, a0, 0x34, frsr a0)
1912771Sqtt2@cornell.edu  TEST_CASE(4, a0, 0x14, frflags a0)
2012771Sqtt2@cornell.edu  TEST_CASE(5, a0, 0x01, csrrwi a0, frm, 2)
2112771Sqtt2@cornell.edu  TEST_CASE(6, a0, 0x54, frsr a0)
2212771Sqtt2@cornell.edu  TEST_CASE(7, a0, 0x14, csrrci a0, fflags, 4)
2312771Sqtt2@cornell.edu  TEST_CASE(8, a0, 0x50, frsr a0)
2412771Sqtt2@cornell.edu
2512771Sqtt2@cornell.edu#define TEST_FSGNJS(n, insn, new_sign, rs1_sign, rs2_sign) \
2612771Sqtt2@cornell.edu  TEST_CASE(n, a0, 0x12345678 | (-(new_sign) << 31), \
2712771Sqtt2@cornell.edu    li a1, ((rs1_sign) << 31) | 0x12345678; \
2812771Sqtt2@cornell.edu    li a2, -(rs2_sign); \
2912771Sqtt2@cornell.edu    fmv.s.x f1, a1; \
3012771Sqtt2@cornell.edu    fmv.s.x f2, a2; \
3112771Sqtt2@cornell.edu    insn f0, f1, f2; \
3212771Sqtt2@cornell.edu    fmv.x.s a0, f0)
3312771Sqtt2@cornell.edu
3412771Sqtt2@cornell.edu  TEST_FSGNJS(10, fsgnj.s, 0, 0, 0)
3512771Sqtt2@cornell.edu  TEST_FSGNJS(11, fsgnj.s, 1, 0, 1)
3612771Sqtt2@cornell.edu  TEST_FSGNJS(12, fsgnj.s, 0, 1, 0)
3712771Sqtt2@cornell.edu  TEST_FSGNJS(13, fsgnj.s, 1, 1, 1)
3812771Sqtt2@cornell.edu
3912771Sqtt2@cornell.edu  TEST_FSGNJS(20, fsgnjn.s, 1, 0, 0)
4012771Sqtt2@cornell.edu  TEST_FSGNJS(21, fsgnjn.s, 0, 0, 1)
4112771Sqtt2@cornell.edu  TEST_FSGNJS(22, fsgnjn.s, 1, 1, 0)
4212771Sqtt2@cornell.edu  TEST_FSGNJS(23, fsgnjn.s, 0, 1, 1)
4312771Sqtt2@cornell.edu
4412771Sqtt2@cornell.edu  TEST_FSGNJS(30, fsgnjx.s, 0, 0, 0)
4512771Sqtt2@cornell.edu  TEST_FSGNJS(31, fsgnjx.s, 1, 0, 1)
4612771Sqtt2@cornell.edu  TEST_FSGNJS(32, fsgnjx.s, 1, 1, 0)
4712771Sqtt2@cornell.edu  TEST_FSGNJS(33, fsgnjx.s, 0, 1, 1)
4812771Sqtt2@cornell.edu
4912771Sqtt2@cornell.edu  TEST_PASSFAIL
5012771Sqtt2@cornell.edu
5112771Sqtt2@cornell.eduRVTEST_CODE_END
5212771Sqtt2@cornell.edu
5312771Sqtt2@cornell.edu  .data
5412771Sqtt2@cornell.eduRVTEST_DATA_BEGIN
5512771Sqtt2@cornell.edu
5612771Sqtt2@cornell.edu  TEST_DATA
5712771Sqtt2@cornell.edu
5812771Sqtt2@cornell.eduRVTEST_DATA_END
59