aboutsummaryrefslogtreecommitdiff
path: root/deps/lightening/tests/mulr.c
blob: 452e35dcb15c5595ccf2def0a08292d097b72b9c (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
#include "test.h"

static void
run_test(jit_state_t *j, uint8_t *arena_base, size_t arena_size)
{
  jit_begin(j, arena_base, arena_size);
  size_t align = jit_enter_jit_abi(j, 0, 0, 0);
  jit_load_args_2(j, jit_operand_gpr (JIT_OPERAND_ABI_WORD, JIT_R0),
                  jit_operand_gpr (JIT_OPERAND_ABI_WORD, JIT_R1));

  jit_mulr(j, JIT_R0, JIT_R0, JIT_R1);
  jit_leave_jit_abi(j, 0, 0, align);
  jit_retr(j, JIT_R0);

  size_t size = 0;
  void* ret = jit_end(j, &size);

  jit_word_t (*f)(jit_word_t, jit_word_t) = ret;

  ASSERT(f(0x7fffffff, 1) == 0x7fffffff);
  ASSERT(f(1, 0x7fffffff) == 0x7fffffff);
  ASSERT(f(0x80000000, 1) == 0x80000000);
  ASSERT(f(1, 0x80000000) == 0x80000000);
  ASSERT(f(0x7fffffff, 2) == 0xfffffffe);
  ASSERT(f(2, 0x7fffffff) == 0xfffffffe);
  ASSERT(f(0x7fffffff, 0) == 0);
  ASSERT(f(0, 0x7fffffff) == 0);
#if __WORDSIZE == 32
  ASSERT(f(0x80000000, 2) == 0);
  ASSERT(f(2, 0x80000000) == 0);
  ASSERT(f(0x7fffffff, 0x80000000) == 0x80000000);
  ASSERT(f(0x80000000, 0x7fffffff) == 0x80000000);
  ASSERT(f(0x7fffffff, 0xffffffff) == 0x80000001);
  ASSERT(f(0xffffffff, 0x7fffffff) == 0x80000001);
  ASSERT(f(0xffffffff, 0xffffffff) == 1);
#else
  ASSERT(f(0x80000000, 2) == 0x100000000);
  ASSERT(f(2, 0x80000000) == 0x100000000);
  ASSERT(f(0x7fffffff, 0x80000000) == 0x3fffffff80000000);
  ASSERT(f(0x80000000, 0x7fffffff) == 0x3fffffff80000000);
  ASSERT(f(0x7fffffff, 0xffffffff) == 0x7ffffffe80000001);
  ASSERT(f(0xffffffff, 0x7fffffff) == 0x7ffffffe80000001);
  ASSERT(f(0xffffffff, 0xffffffff) == 0xfffffffe00000001);
  ASSERT(f(0x7fffffffffffffff, 1) == 0x7fffffffffffffff);
  ASSERT(f(1, 0x7fffffffffffffff) == 0x7fffffffffffffff);
  ASSERT(f(0x8000000000000000, 1) == 0x8000000000000000);
  ASSERT(f(1, 0x8000000000000000) == 0x8000000000000000);
  ASSERT(f(0x7fffffffffffffff, 2) == 0xfffffffffffffffe);
  ASSERT(f(2, 0x7fffffffffffffff) == 0xfffffffffffffffe);
  ASSERT(f(0x8000000000000000, 2) == 0);
  ASSERT(f(2, 0x8000000000000000) == 0);
  ASSERT(f(0x7fffffffffffffff, 0x8000000000000000) == 0x8000000000000000);
  ASSERT(f(0x8000000000000000, 0x7fffffffffffffff) == 0x8000000000000000);
  ASSERT(f(0x7fffffffffffffff, 0xffffffffffffffff) == 0x8000000000000001);
  ASSERT(f(0xffffffffffffffff, 0x7fffffffffffffff) == 0x8000000000000001);
  ASSERT(f(0xffffffffffffffff, 0xffffffffffffffff) == 1);
#endif
}

int
main (int argc, char *argv[])
{
  return main_helper(argc, argv, run_test);
}