1 //===-- negti2_test.c - Test __negti2 -------------------------------------===//
2 //
3 // The LLVM Compiler Infrastructure
4 //
5 // This file is dual licensed under the MIT and the University of Illinois Open
6 // Source Licenses. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // This file tests __negti2 for the compiler_rt library.
11 //
12 //===----------------------------------------------------------------------===//
13
14 #include "int_lib.h"
15 #include <stdio.h>
16
17 #ifdef CRT_HAS_128BIT
18
19 // Returns: -a
20
21 COMPILER_RT_ABI ti_int __negti2(ti_int a);
22
test__negti2(ti_int a,ti_int expected)23 int test__negti2(ti_int a, ti_int expected)
24 {
25 ti_int x = __negti2(a);
26 if (x != expected)
27 {
28 twords at;
29 at.all = a;
30 twords xt;
31 xt.all = x;
32 twords expectedt;
33 expectedt.all = expected;
34 printf("error in __negti2: -0x%.16llX%.16llX = 0x%.16llX%.16llX, "
35 "expected 0x%.16llX%.16llX\n",
36 at.s.high, at.s.low, xt.s.high, xt.s.low, expectedt.s.high, expectedt.s.low);
37 }
38 return x != expected;
39 }
40
41 char assumption_1[sizeof(ti_int) == 2*sizeof(di_int)] = {0};
42
43 #endif
44
main()45 int main()
46 {
47 #ifdef CRT_HAS_128BIT
48 if (test__negti2(0, 0))
49 return 1;
50 if (test__negti2(1, -1))
51 return 1;
52 if (test__negti2(-1, 1))
53 return 1;
54 if (test__negti2(2, -2))
55 return 1;
56 if (test__negti2(-2, 2))
57 return 1;
58 if (test__negti2(3, -3))
59 return 1;
60 if (test__negti2(-3, 3))
61 return 1;
62 if (test__negti2(make_ti(0x0000000000000000LL, 0x00000000FFFFFFFELL),
63 make_ti(0xFFFFFFFFFFFFFFFFLL, 0xFFFFFFFF00000002LL)))
64 return 1;
65 if (test__negti2(make_ti(0xFFFFFFFFFFFFFFFFLL, 0xFFFFFFFF00000002LL),
66 make_ti(0x0000000000000000LL, 0x00000000FFFFFFFELL)))
67 return 1;
68 if (test__negti2(make_ti(0x0000000000000000LL, 0x00000000FFFFFFFFLL),
69 make_ti(0xFFFFFFFFFFFFFFFFLL, 0xFFFFFFFF00000001LL)))
70 return 1;
71 if (test__negti2(make_ti(0xFFFFFFFFFFFFFFFFLL, 0xFFFFFFFF00000001LL),
72 make_ti(0x0000000000000000LL, 0x00000000FFFFFFFFLL)))
73 return 1;
74 if (test__negti2(make_ti(0x0000000000000000LL, 0x0000000100000000LL),
75 make_ti(0xFFFFFFFFFFFFFFFFLL, 0xFFFFFFFF00000000LL)))
76 return 1;
77 if (test__negti2(make_ti(0xFFFFFFFFFFFFFFFFLL, 0xFFFFFFFF00000000LL),
78 make_ti(0x0000000000000000LL, 0x0000000100000000LL)))
79 return 1;
80 if (test__negti2(make_ti(0x0000000000000000LL, 0x0000000200000000LL),
81 make_ti(0xFFFFFFFFFFFFFFFFLL, 0xFFFFFFFE00000000LL)))
82 return 1;
83 if (test__negti2(make_ti(0xFFFFFFFFFFFFFFFFLL, 0xFFFFFFFE00000000LL),
84 make_ti(0x0000000000000000LL, 0x0000000200000000LL)))
85 return 1;
86 if (test__negti2(make_ti(0x0000000000000000LL, 0x0000000300000000LL),
87 make_ti(0xFFFFFFFFFFFFFFFFLL, 0xFFFFFFFD00000000LL)))
88 return 1;
89 if (test__negti2(make_ti(0xFFFFFFFFFFFFFFFFLL, 0xFFFFFFFD00000000LL),
90 make_ti(0x0000000000000000LL, 0x0000000300000000LL)))
91 return 1;
92 if (test__negti2(make_ti(0x0000000000000000LL, 0x7FFFFFFFFFFFFFFFLL),
93 make_ti(0xFFFFFFFFFFFFFFFFLL, 0x8000000000000001LL)))
94 return 1;
95 if (test__negti2(make_ti(0xFFFFFFFFFFFFFFFFLL, 0x8000000000000001LL),
96 make_ti(0x0000000000000000LL, 0x7FFFFFFFFFFFFFFFLL)))
97 return 1;
98 if (test__negti2(make_ti(0x0000000000000000LL, 0x7FFFFFFFFFFFFFFFLL),
99 make_ti(0xFFFFFFFFFFFFFFFFLL, 0x8000000000000001LL)))
100 return 1;
101 if (test__negti2(make_ti(0xFFFFFFFFFFFFFFFFLL, 0xFFFFFFFE00000000LL),
102 make_ti(0x0000000000000000LL, 0x0000000200000000LL)))
103 return 1;
104 if (test__negti2(make_ti(0x0000000000000000LL, 0x0000000200000000LL),
105 make_ti(0xFFFFFFFFFFFFFFFFLL, 0xFFFFFFFE00000000LL)))
106 return 1;
107 if (test__negti2(make_ti(0xFFFFFFFFFFFFFFFFLL, 0xFFFFFFFF00000000LL),
108 make_ti(0x0000000000000000LL, 0x0000000100000000LL)))
109 return 1;
110 if (test__negti2(make_ti(0x0000000000000000LL, 0x0000000100000000LL),
111 make_ti(0xFFFFFFFFFFFFFFFFLL, 0xFFFFFFFF00000000LL)))
112 return 1;
113 if (test__negti2(make_ti(0x8000000000000000LL, 0x0000000000000000LL),
114 make_ti(0x8000000000000000LL, 0x0000000000000000LL)))
115 return 1;
116 if (test__negti2(make_ti(0x8000000000000000LL, 0x0000000000000001LL),
117 make_ti(0x7FFFFFFFFFFFFFFFLL, 0xFFFFFFFFFFFFFFFFLL)))
118 return 1;
119 if (test__negti2(make_ti(0x7FFFFFFFFFFFFFFFLL, 0xFFFFFFFFFFFFFFFFLL),
120 make_ti(0x8000000000000000LL, 0x0000000000000001LL)))
121 return 1;
122
123 #else
124 printf("skipped\n");
125 #endif
126 return 0;
127 }
128