aboutsummaryrefslogtreecommitdiff
path: root/tests/divr.c
diff options
context:
space:
mode:
authorKimplul <kimi.h.kuparinen@gmail.com>2024-07-13 20:56:26 +0300
committerKimplul <kimi.h.kuparinen@gmail.com>2024-07-13 20:56:26 +0300
commitae9e103995c1d809be7b8717905593e7dbbf9d17 (patch)
tree0ceaf6ee66e1d67bb8d0b9dd6f37b5687e4c2f09 /tests/divr.c
parente618924df98d4ee5037db86c768a8c8014e49c4c (diff)
downloadejit-ae9e103995c1d809be7b8717905593e7dbbf9d17.tar.gz
ejit-ae9e103995c1d809be7b8717905593e7dbbf9d17.zip
bytecode tests pass
Diffstat (limited to 'tests/divr.c')
-rw-r--r--tests/divr.c152
1 files changed, 0 insertions, 152 deletions
diff --git a/tests/divr.c b/tests/divr.c
deleted file mode 100644
index e16a8bf..0000000
--- a/tests/divr.c
+++ /dev/null
@@ -1,152 +0,0 @@
-#include <ejit/ejit.h>
-#include <assert.h>
-#include "do_jit.h"
-
-int main()
-{
- struct ejit_operand operands[2] = {
- EJIT_OPERAND_GPR(0, EJIT_TYPE(long)),
- EJIT_OPERAND_GPR(1, EJIT_TYPE(long))
- };
- struct ejit_func *f = ejit_create_func(EJIT_TYPE(long), 2, operands);
-
- ejit_divr(f, EJIT_GPR(0), EJIT_GPR(0), EJIT_GPR(1));
- ejit_retr(f, EJIT_GPR(0));
-
- ejit_select_compile_func(f, 2, 0, EJIT_USE64(long), do_jit);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0x7fffffff, long),
- EJIT_ARG(1, long)) == 0x7fffffff);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(1, long),
- EJIT_ARG(0x7fffffff, long)) == 0);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0x80000000, long),
- EJIT_ARG(1, long)) == 0x80000000);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(1, long),
- EJIT_ARG(0x80000000, long)) == 0);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0x7fffffff, long),
- EJIT_ARG(2, long)) == 0x3fffffff);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(2, long),
- EJIT_ARG(0x7fffffff, long)) == 0);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(2, long),
- EJIT_ARG(0x80000000, long)) == 0);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0x7fffffff, long),
- EJIT_ARG(0x80000000, long)) == 0);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0, long),
- EJIT_ARG(0x7fffffff, long)) == 0);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0xffffffff, long),
- EJIT_ARG(0xffffffff, long)) == 1);
-
-#warning "Some 32bit handling still unclear"
- /* 32bit specific stuff, unsure how this should be handled on 64bit
- * systems
- assert(ejit_run_func_2(f,
- EJIT_ARG(0x80000000, long),
- EJIT_ARG(2, long)) == 0xc0000000);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0x80000000, long),
- EJIT_ARG(0x7fffffff, long)) == 0xffffffff);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0x7fffffff, long),
- EJIT_ARG(0xffffffff, long)) == 0x80000001);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0xffffffff, long),
- EJIT_ARG(0x7fffffff, long)) == 0);
- */
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0x80000000, long),
- EJIT_ARG(2, long)) == 0x40000000);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0x80000000, long),
- EJIT_ARG(0x7fffffff, long)) == 1);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0x7fffffff, long),
- EJIT_ARG(0xffffffff, long)) == 0);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0xffffffff, long),
- EJIT_ARG(0x7fffffff, long)) == 2);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0x7fffffffffffffff, long),
- EJIT_ARG(1, long)) == 0x7fffffffffffffff);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(1, long),
- EJIT_ARG(0x7fffffffffffffff, long)) == 0);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0x8000000000000000, long),
- EJIT_ARG(1, long))
- == (int64_t)0x8000000000000000);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(1, long),
- EJIT_ARG(0x8000000000000000, long)) == 0);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0x7fffffffffffffff, long),
- EJIT_ARG(2, long))
- == (int64_t)0x3fffffffffffffff);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(2, long),
- EJIT_ARG(0x7fffffffffffffff, long)) == 0);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0x8000000000000000, long),
- EJIT_ARG(2, long))
- == (int64_t)0xc000000000000000);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(2, long),
- EJIT_ARG(0x8000000000000000, long)) == 0);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0x7fffffffffffffff, long),
- EJIT_ARG(0x8000000000000000, long)) == 0);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0x8000000000000000, long),
- EJIT_ARG(0x7fffffffffffffff, long))
- == (int32_t)0xffffffffffffffff);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0x7fffffffffffffff, long),
- EJIT_ARG(0xffffffffffffffff, long))
- == (int32_t)0x8000000000000001);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0xffffffffffffffff, long),
- EJIT_ARG(0x7fffffffffffffff, long)) == 0);
-
- assert(ejit_run_func_2(f,
- EJIT_ARG(0xffffffffffffffff, long),
- EJIT_ARG(0xffffffffffffffff, long)) == 1);
-
- ejit_destroy_func(f);
-}