1 //===-- mulodi4_test.c - Test __mulodi4 -----------------------------------===//
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 __mulodi4 for the compiler_rt library.
11 //
12 //===----------------------------------------------------------------------===//
13 
14 #include "int_lib.h"
15 #include <stdio.h>
16 
17 extern COMPILER_RT_ABI di_int __mulodi4(di_int a, di_int b, int* overflow);
18 
test__mulodi4(di_int a,di_int b,di_int expected,int expected_overflow)19 int test__mulodi4(di_int a, di_int b, di_int expected, int expected_overflow)
20 {
21     int ov;
22     di_int x = __mulodi4(a, b, &ov);
23     if (ov != expected_overflow)
24       printf("error in __mulodi4: overflow=%d expected=%d\n",
25 	     ov, expected_overflow);
26     else if (!expected_overflow && x != expected) {
27         printf("error in __mulodi4: 0x%llX * 0x%llX = 0x%llX (overflow=%d), "
28 			   "expected 0x%llX (overflow=%d)\n",
29                a, b, x, ov, expected, expected_overflow);
30 		return 1;
31     }
32     return 0;
33 }
34 
main()35 int main()
36 {
37     if (test__mulodi4(0, 0, 0, 0))
38         return 1;
39     if (test__mulodi4(0, 1, 0, 0))
40         return 1;
41     if (test__mulodi4(1, 0, 0, 0))
42         return 1;
43     if (test__mulodi4(0, 10, 0, 0))
44         return 1;
45     if (test__mulodi4(10, 0, 0, 0))
46         return 1;
47     if (test__mulodi4(0, 81985529216486895LL, 0, 0))
48         return 1;
49     if (test__mulodi4(81985529216486895LL, 0, 0, 0))
50         return 1;
51 
52     if (test__mulodi4(0, -1, 0, 0))
53         return 1;
54     if (test__mulodi4(-1, 0, 0, 0))
55         return 1;
56     if (test__mulodi4(0, -10, 0, 0))
57         return 1;
58     if (test__mulodi4(-10, 0, 0, 0))
59         return 1;
60     if (test__mulodi4(0, -81985529216486895LL, 0, 0))
61         return 1;
62     if (test__mulodi4(-81985529216486895LL, 0, 0, 0))
63         return 1;
64 
65     if (test__mulodi4(1, 1, 1, 0))
66         return 1;
67     if (test__mulodi4(1, 10, 10, 0))
68         return 1;
69     if (test__mulodi4(10, 1, 10, 0))
70         return 1;
71     if (test__mulodi4(1, 81985529216486895LL, 81985529216486895LL, 0))
72         return 1;
73     if (test__mulodi4(81985529216486895LL, 1, 81985529216486895LL, 0))
74         return 1;
75 
76     if (test__mulodi4(1, -1, -1, 0))
77         return 1;
78     if (test__mulodi4(1, -10, -10, 0))
79         return 1;
80     if (test__mulodi4(-10, 1, -10, 0))
81         return 1;
82     if (test__mulodi4(1, -81985529216486895LL, -81985529216486895LL, 0))
83         return 1;
84     if (test__mulodi4(-81985529216486895LL, 1, -81985529216486895LL, 0))
85         return 1;
86 
87     if (test__mulodi4(3037000499LL, 3037000499LL, 9223372030926249001LL, 0))
88         return 1;
89     if (test__mulodi4(-3037000499LL, 3037000499LL, -9223372030926249001LL, 0))
90         return 1;
91     if (test__mulodi4(3037000499LL, -3037000499LL, -9223372030926249001LL, 0))
92         return 1;
93     if (test__mulodi4(-3037000499LL, -3037000499LL, 9223372030926249001LL, 0))
94         return 1;
95 
96     if (test__mulodi4(4398046511103LL, 2097152LL, 9223372036852678656LL, 0))
97         return 1;
98     if (test__mulodi4(-4398046511103LL, 2097152LL, -9223372036852678656LL, 0))
99         return 1;
100     if (test__mulodi4(4398046511103LL, -2097152LL, -9223372036852678656LL, 0))
101         return 1;
102     if (test__mulodi4(-4398046511103LL, -2097152LL, 9223372036852678656LL, 0))
103         return 1;
104 
105     if (test__mulodi4(2097152LL, 4398046511103LL, 9223372036852678656LL, 0))
106         return 1;
107     if (test__mulodi4(-2097152LL, 4398046511103LL, -9223372036852678656LL, 0))
108         return 1;
109     if (test__mulodi4(2097152LL, -4398046511103LL, -9223372036852678656LL, 0))
110         return 1;
111     if (test__mulodi4(-2097152LL, -4398046511103LL, 9223372036852678656LL, 0))
112         return 1;
113 
114      if (test__mulodi4(0x7FFFFFFFFFFFFFFFLL, -2, 2, 1))
115          return 1;
116      if (test__mulodi4(-2, 0x7FFFFFFFFFFFFFFFLL, 2, 1))
117          return 1;
118     if (test__mulodi4(0x7FFFFFFFFFFFFFFFLL, -1, 0x8000000000000001LL, 0))
119         return 1;
120     if (test__mulodi4(-1, 0x7FFFFFFFFFFFFFFFLL, 0x8000000000000001LL, 0))
121         return 1;
122     if (test__mulodi4(0x7FFFFFFFFFFFFFFFLL, 0, 0, 0))
123         return 1;
124     if (test__mulodi4(0, 0x7FFFFFFFFFFFFFFFLL, 0, 0))
125         return 1;
126     if (test__mulodi4(0x7FFFFFFFFFFFFFFFLL, 1, 0x7FFFFFFFFFFFFFFFLL, 0))
127         return 1;
128     if (test__mulodi4(1, 0x7FFFFFFFFFFFFFFFLL, 0x7FFFFFFFFFFFFFFFLL, 0))
129         return 1;
130      if (test__mulodi4(0x7FFFFFFFFFFFFFFFLL, 2, 0x8000000000000001LL, 1))
131          return 1;
132      if (test__mulodi4(2, 0x7FFFFFFFFFFFFFFFLL, 0x8000000000000001LL, 1))
133          return 1;
134 
135      if (test__mulodi4(0x8000000000000000LL, -2, 0x8000000000000000LL, 1))
136          return 1;
137      if (test__mulodi4(-2, 0x8000000000000000LL, 0x8000000000000000LL, 1))
138          return 1;
139      if (test__mulodi4(0x8000000000000000LL, -1, 0x8000000000000000LL, 1))
140          return 1;
141      if (test__mulodi4(-1, 0x8000000000000000LL, 0x8000000000000000LL, 1))
142          return 1;
143     if (test__mulodi4(0x8000000000000000LL, 0, 0, 0))
144         return 1;
145     if (test__mulodi4(0, 0x8000000000000000LL, 0, 0))
146         return 1;
147     if (test__mulodi4(0x8000000000000000LL, 1, 0x8000000000000000LL, 0))
148         return 1;
149     if (test__mulodi4(1, 0x8000000000000000LL, 0x8000000000000000LL, 0))
150         return 1;
151      if (test__mulodi4(0x8000000000000000LL, 2, 0x8000000000000000LL, 1))
152          return 1;
153      if (test__mulodi4(2, 0x8000000000000000LL, 0x8000000000000000LL, 1))
154          return 1;
155 
156      if (test__mulodi4(0x8000000000000001LL, -2, 0x8000000000000001LL, 1))
157          return 1;
158      if (test__mulodi4(-2, 0x8000000000000001LL, 0x8000000000000001LL, 1))
159          return 1;
160     if (test__mulodi4(0x8000000000000001LL, -1, 0x7FFFFFFFFFFFFFFFLL, 0))
161         return 1;
162     if (test__mulodi4(-1, 0x8000000000000001LL, 0x7FFFFFFFFFFFFFFFLL, 0))
163         return 1;
164     if (test__mulodi4(0x8000000000000001LL, 0, 0, 0))
165         return 1;
166     if (test__mulodi4(0, 0x8000000000000001LL, 0, 0))
167         return 1;
168     if (test__mulodi4(0x8000000000000001LL, 1, 0x8000000000000001LL, 0))
169         return 1;
170     if (test__mulodi4(1, 0x8000000000000001LL, 0x8000000000000001LL, 0))
171         return 1;
172      if (test__mulodi4(0x8000000000000001LL, 2, 0x8000000000000000LL, 1))
173          return 1;
174      if (test__mulodi4(2, 0x8000000000000001LL, 0x8000000000000000LL, 1))
175          return 1;
176 
177     return 0;
178 }
179