aboutsummaryrefslogtreecommitdiffhomepage
path: root/externals/biscuit/tests/src/assembler_rvb_tests.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'externals/biscuit/tests/src/assembler_rvb_tests.cpp')
-rw-r--r--externals/biscuit/tests/src/assembler_rvb_tests.cpp610
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);
+}