diff options
author | Kimplul <kimi.h.kuparinen@gmail.com> | 2024-07-13 20:56:26 +0300 |
---|---|---|
committer | Kimplul <kimi.h.kuparinen@gmail.com> | 2024-07-13 20:56:26 +0300 |
commit | ae9e103995c1d809be7b8717905593e7dbbf9d17 (patch) | |
tree | 0ceaf6ee66e1d67bb8d0b9dd6f37b5687e4c2f09 /tests/negr.c | |
parent | e618924df98d4ee5037db86c768a8c8014e49c4c (diff) | |
download | ejit-ae9e103995c1d809be7b8717905593e7dbbf9d17.tar.gz ejit-ae9e103995c1d809be7b8717905593e7dbbf9d17.zip |
bytecode tests pass
Diffstat (limited to 'tests/negr.c')
-rw-r--r-- | tests/negr.c | 64 |
1 files changed, 32 insertions, 32 deletions
diff --git a/tests/negr.c b/tests/negr.c index db65f3c..4e3b34c 100644 --- a/tests/negr.c +++ b/tests/negr.c @@ -1,39 +1,39 @@ -#include "test.h" +#include <ejit/ejit.h> +#include <assert.h> +#include "do_jit.h" -static void -run_test(jit_state_t *j, uint8_t *arena_base, size_t arena_size) +int main() { - jit_begin(j, arena_base, arena_size); - size_t align = jit_enter_jit_abi(j, 0, 0, 0); - jit_load_args_1(j, jit_operand_gpr (JIT_OPERAND_ABI_WORD, JIT_R0)); + struct ejit_operand operands[1] = { + EJIT_OPERAND_GPR(0, EJIT_TYPE(int64_t)) + }; + struct ejit_func *f = ejit_create_func(EJIT_TYPE(int64_t), 1, operands); - jit_negr(j, JIT_R0, JIT_R0); - jit_leave_jit_abi(j, 0, 0, align); - jit_retr(j, JIT_R0); + ejit_negr(f, EJIT_GPR(0), EJIT_GPR(0)); + ejit_retr(f, EJIT_GPR(0)); - jit_word_t (*f)(jit_word_t) = jit_end(j, NULL); + ejit_select_compile_func(f, 1, 0, EJIT_USE64(int64_t), do_jit); - ASSERT(f(0) == 0); -#if EJIT_WORDSIZE == 32 - ASSERT(f(1) == 0xffffffff); - ASSERT(f(0xffffffff) == 1); - ASSERT(f(0x80000000) == 0x80000000); - ASSERT(f(0x7fffffff) == 0x80000001); - ASSERT(f(0x80000001) == 0x7fffffff); -#else - ASSERT(f(1) == 0xffffffffffffffff); - ASSERT(f(0xffffffff) == 0xffffffff00000001); - ASSERT(f(0x80000000) == 0xffffffff80000000); - ASSERT(f(0x7fffffff) == 0xffffffff80000001); - ASSERT(f(0x80000001) == 0xffffffff7fffffff); - ASSERT(f(0xffffffffffffffff) == 1); - ASSERT(f(0x8000000000000000) == 0x8000000000000000); - ASSERT(f(0x7fffffffffffffff) == 0x8000000000000001); -#endif -} + assert(erf1(f, EJIT_ARG(0, int64_t)) == 0); + assert(erf1(f, EJIT_ARG(1, int64_t)) == (int64_t)0xffffffffffffffff); + assert(erf1(f, + EJIT_ARG(0xffffffff, + int64_t)) == (int64_t)0xffffffff00000001); + assert(erf1(f, + EJIT_ARG(0x80000000, + int64_t)) == (int64_t)0xffffffff80000000); + assert(erf1(f, + EJIT_ARG(0x7fffffff, + int64_t)) == (int64_t)0xffffffff80000001); + assert(erf1(f, + EJIT_ARG(0x80000001, + int64_t)) == (int64_t)0xffffffff7fffffff); + assert(erf1(f, EJIT_ARG(0xffffffffffffffff, int64_t)) == 1); + assert(erf1(f, EJIT_ARG(0x8000000000000000, int64_t)) + == (int64_t)0x8000000000000000); -int -main (int argc, char *argv[]) -{ - return main_helper(argc, argv, run_test); + assert(erf1(f, EJIT_ARG(0x7fffffffffffffff, int64_t)) + == (int64_t)0x8000000000000001); + + ejit_destroy_func(f); } |