diff options
Diffstat (limited to 'externals/biscuit/tests/src/assembler_rvb_tests.cpp')
-rw-r--r-- | externals/biscuit/tests/src/assembler_rvb_tests.cpp | 610 |
1 files changed, 610 insertions, 0 deletions
diff --git a/externals/biscuit/tests/src/assembler_rvb_tests.cpp b/externals/biscuit/tests/src/assembler_rvb_tests.cpp new file mode 100644 index 00000000..ba39f002 --- /dev/null +++ b/externals/biscuit/tests/src/assembler_rvb_tests.cpp @@ -0,0 +1,610 @@ +#include <catch/catch.hpp> + +#include <biscuit/assembler.hpp> + +#include "assembler_test_utils.hpp" + +using namespace biscuit; + +TEST_CASE("ADD.UW", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler64(value); + + as.ADDUW(x31, x7, x15); + REQUIRE(value == 0x08F38FBB); + + as.RewindBuffer(); + + // Pseudo instruction + + as.ZEXTW(x31, x7); + REQUIRE(value == 0x08038FBB); +} + +TEST_CASE("ANDN", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.ANDN(x31, x7, x15); + REQUIRE(value == 0x40F3FFB3); +} + +TEST_CASE("BCLR", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.BCLR(x31, x7, x15); + REQUIRE(value == 0x48F39FB3); +} + +TEST_CASE("BCLRI", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.BCLRI(x31, x7, 0); + REQUIRE(value == 0x48039F93); + + as.RewindBuffer(); + + as.BCLRI(x31, x7, 15); + REQUIRE(value == 0x48F39F93); + + as.RewindBuffer(); + + as.BCLRI(x31, x7, 31); + REQUIRE(value == 0x49F39F93); +} + +TEST_CASE("BCLRI (RV64)", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler64(value); + + as.BCLRI(x31, x7, 0); + REQUIRE(value == 0x48039F93); + + as.RewindBuffer(); + + as.BCLRI(x31, x7, 15); + REQUIRE(value == 0x48F39F93); + + as.RewindBuffer(); + + as.BCLRI(x31, x7, 31); + REQUIRE(value == 0x49F39F93); + + as.RewindBuffer(); + + as.BCLRI(x31, x7, 63); + REQUIRE(value == 0x4BF39F93); +} + +TEST_CASE("BEXT", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.BEXT(x31, x7, x15); + REQUIRE(value == 0x48F3DFB3); +} + +TEST_CASE("BEXTI", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.BEXTI(x31, x7, 0); + REQUIRE(value == 0x4803DF93); + + as.RewindBuffer(); + + as.BEXTI(x31, x7, 15); + REQUIRE(value == 0x48F3DF93); + + as.RewindBuffer(); + + as.BEXTI(x31, x7, 31); + REQUIRE(value == 0x49F3DF93); +} + +TEST_CASE("BEXTI (RV64)", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler64(value); + + as.BEXTI(x31, x7, 0); + REQUIRE(value == 0x4803DF93); + + as.RewindBuffer(); + + as.BEXTI(x31, x7, 15); + REQUIRE(value == 0x48F3DF93); + + as.RewindBuffer(); + + as.BEXTI(x31, x7, 31); + REQUIRE(value == 0x49F3DF93); + + as.RewindBuffer(); + + as.BEXTI(x31, x7, 63); + REQUIRE(value == 0x4BF3DF93); +} + +TEST_CASE("BINV", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.BINV(x31, x7, x15); + REQUIRE(value == 0x68F39FB3); +} + +TEST_CASE("BINVI", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.BINVI(x31, x7, 0); + REQUIRE(value == 0x68039F93); + + as.RewindBuffer(); + + as.BINVI(x31, x7, 15); + REQUIRE(value == 0x68F39F93); + + as.RewindBuffer(); + + as.BINVI(x31, x7, 31); + REQUIRE(value == 0x69F39F93); +} + +TEST_CASE("BINVI (RV64)", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler64(value); + + as.BINVI(x31, x7, 0); + REQUIRE(value == 0x68039F93); + + as.RewindBuffer(); + + as.BINVI(x31, x7, 15); + REQUIRE(value == 0x68F39F93); + + as.RewindBuffer(); + + as.BINVI(x31, x7, 31); + REQUIRE(value == 0x69F39F93); + + as.RewindBuffer(); + + as.BINVI(x31, x7, 63); + REQUIRE(value == 0x6BF39F93); +} + +TEST_CASE("BREV8", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.BREV8(x31, x31); + REQUIRE(value == 0x687FDF93); + + as.RewindBuffer(); + + as.BREV8(x1, x2); + REQUIRE(value == 0x68715093); +} + +TEST_CASE("BSET", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.BSET(x31, x7, x15); + REQUIRE(value == 0x28F39FB3); +} + +TEST_CASE("BSETI", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.BSETI(x31, x7, 0); + REQUIRE(value == 0x28039FB3); + + as.RewindBuffer(); + + as.BSETI(x31, x7, 15); + REQUIRE(value == 0x28F39FB3); + + as.RewindBuffer(); + + as.BSETI(x31, x7, 31); + REQUIRE(value == 0x29F39FB3); +} + +TEST_CASE("BSETI (RV64)", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler64(value); + + as.BSETI(x31, x7, 0); + REQUIRE(value == 0x28039FB3); + + as.RewindBuffer(); + + as.BSETI(x31, x7, 15); + REQUIRE(value == 0x28F39FB3); + + as.RewindBuffer(); + + as.BSETI(x31, x7, 31); + REQUIRE(value == 0x29F39FB3); + + as.RewindBuffer(); + + as.BSETI(x31, x7, 63); + REQUIRE(value == 0x2BF39FB3); +} + +TEST_CASE("CLMUL", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.CLMUL(x31, x7, x15); + REQUIRE(value == 0x0AF39FB3); +} + +TEST_CASE("CLMULH", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.CLMULH(x31, x7, x15); + REQUIRE(value == 0x0AF3BFB3); +} + +TEST_CASE("CLMULR", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.CLMULR(x31, x7, x15); + REQUIRE(value == 0x0AF3AFB3); +} + +TEST_CASE("CLZ", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.CLZ(x31, x7); + REQUIRE(value == 0x60039F93); +} + +TEST_CASE("CLZW", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler64(value); + + as.CLZW(x31, x7); + REQUIRE(value == 0x60039F9B); +} + +TEST_CASE("CPOP", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.CPOP(x31, x7); + REQUIRE(value == 0x60239F93); +} + +TEST_CASE("CPOPW", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler64(value); + + as.CPOPW(x31, x7); + REQUIRE(value == 0x60239F9B); +} + +TEST_CASE("CTZ", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.CTZ(x31, x7); + REQUIRE(value == 0x60139F93); +} + +TEST_CASE("CTZW", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler64(value); + + as.CTZW(x31, x7); + REQUIRE(value == 0x60139F9B); +} + +TEST_CASE("MAX", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.MAX(x31, x7, x15); + REQUIRE(value == 0x0AF3EFB3); +} + +TEST_CASE("MAXU", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.MAXU(x31, x7, x15); + REQUIRE(value == 0x0AF3FFB3); +} + +TEST_CASE("MIN", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.MIN(x31, x7, x15); + REQUIRE(value == 0x0AF3CFB3); +} + +TEST_CASE("MINU", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.MINU(x31, x7, x15); + REQUIRE(value == 0x0AF3DFB3); +} + +TEST_CASE("ORC.B", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.ORCB(x31, x7); + REQUIRE(value == 0x2873DF93); +} + +TEST_CASE("ORN", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.ORN(x31, x7, x15); + REQUIRE(value == 0x40F3EFB3); +} + +TEST_CASE("PACK", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.PACK(x31, x7, x2); + REQUIRE(value == 0x0823CFB3); +} + +TEST_CASE("PACKH", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.PACKH(x31, x7, x2); + REQUIRE(value == 0x0823FFB3); +} + +TEST_CASE("PACKW", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler64(value); + + as.PACKW(x31, x7, x2); + REQUIRE(value == 0x0823CFBB); +} + +TEST_CASE("REV8", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.REV8(x31, x7); + REQUIRE(value == 0x6983DF93); +} + +TEST_CASE("REV8 (RV64)", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler64(value); + + as.REV8(x31, x7); + REQUIRE(value == 0x6B83DF93); +} + +TEST_CASE("ROL", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.ROL(x31, x7, x15); + REQUIRE(value == 0x60F39FB3); +} + +TEST_CASE("ROLW", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler64(value); + + as.ROLW(x31, x7, x15); + REQUIRE(value == 0x60F39FBB); +} + +TEST_CASE("ROR", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.ROR(x31, x7, x15); + REQUIRE(value == 0x60F3DFB3); +} + +TEST_CASE("RORW", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler64(value); + + as.RORW(x31, x7, x15); + REQUIRE(value == 0x60F3DFBB); +} + +TEST_CASE("RORI", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.RORI(x31, x7, 0); + REQUIRE(value == 0x6003DF93); + + as.RewindBuffer(); + + as.RORI(x31, x7, 63); + REQUIRE(value == 0x63F3DF93); +} + +TEST_CASE("RORIW", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler64(value); + + as.RORIW(x31, x7, 0); + REQUIRE(value == 0x6003DF9B); + + as.RewindBuffer(); + + as.RORIW(x31, x7, 63); + REQUIRE(value == 0x63F3DF9B); +} + +TEST_CASE("SEXT.B", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.SEXTB(x31, x7); + REQUIRE(value == 0x60439F93); +} + +TEST_CASE("SEXT.H", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.SEXTH(x31, x7); + REQUIRE(value == 0x60539F93); +} + +TEST_CASE("SH1ADD", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.SH1ADD(x31, x7, x15); + REQUIRE(value == 0x20F3AFB3); +} + +TEST_CASE("SH1ADD.UW", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler64(value); + + as.SH1ADDUW(x31, x7, x15); + REQUIRE(value == 0x20F3AFBB); +} + +TEST_CASE("SH2ADD", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.SH2ADD(x31, x7, x15); + REQUIRE(value == 0x20F3CFB3); +} + +TEST_CASE("SH2ADD.UW", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler64(value); + + as.SH2ADDUW(x31, x7, x15); + REQUIRE(value == 0x20F3CFBB); +} + +TEST_CASE("SH3ADD", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.SH3ADD(x31, x7, x15); + REQUIRE(value == 0x20F3EFB3); +} + +TEST_CASE("SH3ADD.UW", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler64(value); + + as.SH3ADDUW(x31, x7, x15); + REQUIRE(value == 0x20F3EFBB); +} + +TEST_CASE("SLLI.UW", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler64(value); + + as.SLLIUW(x31, x7, 0); + REQUIRE(value == 0x08039F9B); + + as.RewindBuffer(); + + as.SLLIUW(x31, x7, 63); + REQUIRE(value == 0x0BF39F9B); +} + +TEST_CASE("UNZIP", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.UNZIP(x31, x31); + REQUIRE(value == 0x09FFDF93); + + as.RewindBuffer(); + + as.UNZIP(x1, x2); + REQUIRE(value == 0x09F15093); +} + +TEST_CASE("XNOR", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.XNOR(x31, x7, x15); + REQUIRE(value == 0x40F3CFB3); +} + +TEST_CASE("XPERM4", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.XPERM4(x31, x31, x31); + REQUIRE(value == 0x29FFAFB3); + + as.RewindBuffer(); + + as.XPERM4(x1, x2, x3); + REQUIRE(value == 0x283120B3); +} + +TEST_CASE("XPERM8", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.XPERM8(x31, x31, x31); + REQUIRE(value == 0x29FFCFB3); + + as.RewindBuffer(); + + as.XPERM8(x1, x2, x3); + REQUIRE(value == 0x283140B3); +} + +TEST_CASE("ZEXT.H", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.ZEXTH(x31, x7); + REQUIRE(value == 0x0803CFB3); +} + +TEST_CASE("ZEXT.H (RV64)", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler64(value); + + as.ZEXTH(x31, x7); + REQUIRE(value == 0x0803CFBB); +} + +TEST_CASE("ZIP", "[rvb]") { + uint32_t value = 0; + auto as = MakeAssembler32(value); + + as.ZIP(x31, x31); + REQUIRE(value == 0x09EF9F93); + + as.RewindBuffer(); + + as.ZIP(x1, x2); + REQUIRE(value == 0x09E11093); +} |