xref: /netbsd-src/sys/external/bsd/compiler_rt/dist/test/Unit/mulosi4_test.c (revision b9829059e8a75f40496c2d279251f331078ac82e)
1*b9829059Sjoerg //===-- mulosi4_test.c - Test __mulosi4 -----------------------------------===//
2*b9829059Sjoerg //
3*b9829059Sjoerg //                     The LLVM Compiler Infrastructure
4*b9829059Sjoerg //
5*b9829059Sjoerg // This file is dual licensed under the MIT and the University of Illinois Open
6*b9829059Sjoerg // Source Licenses. See LICENSE.TXT for details.
7*b9829059Sjoerg //
8*b9829059Sjoerg //===----------------------------------------------------------------------===//
9*b9829059Sjoerg //
10*b9829059Sjoerg // This file tests __mulosi4 for the compiler_rt library.
11*b9829059Sjoerg //
12*b9829059Sjoerg //===----------------------------------------------------------------------===//
13*b9829059Sjoerg 
14*b9829059Sjoerg #include "int_lib.h"
15*b9829059Sjoerg #include <stdio.h>
16*b9829059Sjoerg 
17*b9829059Sjoerg // Returns: a * b
18*b9829059Sjoerg 
19*b9829059Sjoerg // Effects: aborts if a * b overflows
20*b9829059Sjoerg 
21*b9829059Sjoerg si_int __mulosi4(si_int a, si_int b, int *overflow);
22*b9829059Sjoerg 
test__mulosi4(si_int a,si_int b,si_int expected,int expected_overflow)23*b9829059Sjoerg int test__mulosi4(si_int a, si_int b, si_int expected, int expected_overflow)
24*b9829059Sjoerg {
25*b9829059Sjoerg   int ov;
26*b9829059Sjoerg   si_int x = __mulosi4(a, b, &ov);
27*b9829059Sjoerg   if (ov != expected_overflow)
28*b9829059Sjoerg     printf("error in __mulosi4: overflow=%d expected=%d\n",
29*b9829059Sjoerg 	   ov, expected_overflow);
30*b9829059Sjoerg   else if (!expected_overflow && x != expected) {
31*b9829059Sjoerg     printf("error in __mulosi4: 0x%X * 0x%X = 0x%X (overflow=%d), "
32*b9829059Sjoerg 	   "expected 0x%X (overflow=%d)\n",
33*b9829059Sjoerg 	   a, b, x, ov, expected, expected_overflow);
34*b9829059Sjoerg     return 1;
35*b9829059Sjoerg   }
36*b9829059Sjoerg   return 0;
37*b9829059Sjoerg }
38*b9829059Sjoerg 
39*b9829059Sjoerg 
main()40*b9829059Sjoerg int main()
41*b9829059Sjoerg {
42*b9829059Sjoerg     if (test__mulosi4(0, 0, 0, 0))
43*b9829059Sjoerg         return 1;
44*b9829059Sjoerg     if (test__mulosi4(0, 1, 0, 0))
45*b9829059Sjoerg         return 1;
46*b9829059Sjoerg     if (test__mulosi4(1, 0, 0, 0))
47*b9829059Sjoerg         return 1;
48*b9829059Sjoerg     if (test__mulosi4(0, 10, 0, 0))
49*b9829059Sjoerg         return 1;
50*b9829059Sjoerg     if (test__mulosi4(10, 0, 0, 0))
51*b9829059Sjoerg         return 1;
52*b9829059Sjoerg     if (test__mulosi4(0, 0x1234567, 0, 0))
53*b9829059Sjoerg         return 1;
54*b9829059Sjoerg     if (test__mulosi4(0x1234567, 0, 0, 0))
55*b9829059Sjoerg         return 1;
56*b9829059Sjoerg 
57*b9829059Sjoerg     if (test__mulosi4(0, -1, 0, 0))
58*b9829059Sjoerg         return 1;
59*b9829059Sjoerg     if (test__mulosi4(-1, 0, 0, 0))
60*b9829059Sjoerg         return 1;
61*b9829059Sjoerg     if (test__mulosi4(0, -10, 0, 0))
62*b9829059Sjoerg         return 1;
63*b9829059Sjoerg     if (test__mulosi4(-10, 0, 0, 0))
64*b9829059Sjoerg         return 1;
65*b9829059Sjoerg     if (test__mulosi4(0, -0x1234567, 0, 0))
66*b9829059Sjoerg         return 1;
67*b9829059Sjoerg     if (test__mulosi4(-0x1234567, 0, 0, 0))
68*b9829059Sjoerg         return 1;
69*b9829059Sjoerg 
70*b9829059Sjoerg     if (test__mulosi4(1, 1, 1, 0))
71*b9829059Sjoerg         return 1;
72*b9829059Sjoerg     if (test__mulosi4(1, 10, 10, 0))
73*b9829059Sjoerg         return 1;
74*b9829059Sjoerg     if (test__mulosi4(10, 1, 10, 0))
75*b9829059Sjoerg         return 1;
76*b9829059Sjoerg     if (test__mulosi4(1, 0x1234567, 0x1234567, 0))
77*b9829059Sjoerg         return 1;
78*b9829059Sjoerg     if (test__mulosi4(0x1234567, 1, 0x1234567, 0))
79*b9829059Sjoerg         return 1;
80*b9829059Sjoerg 
81*b9829059Sjoerg     if (test__mulosi4(1, -1, -1, 0))
82*b9829059Sjoerg         return 1;
83*b9829059Sjoerg     if (test__mulosi4(1, -10, -10, 0))
84*b9829059Sjoerg         return 1;
85*b9829059Sjoerg     if (test__mulosi4(-10, 1, -10, 0))
86*b9829059Sjoerg         return 1;
87*b9829059Sjoerg     if (test__mulosi4(1, -0x1234567, -0x1234567, 0))
88*b9829059Sjoerg         return 1;
89*b9829059Sjoerg     if (test__mulosi4(-0x1234567, 1, -0x1234567, 0))
90*b9829059Sjoerg         return 1;
91*b9829059Sjoerg 
92*b9829059Sjoerg      if (test__mulosi4(0x7FFFFFFF, -2, 0x80000001, 1))
93*b9829059Sjoerg          return 1;
94*b9829059Sjoerg      if (test__mulosi4(-2, 0x7FFFFFFF, 0x80000001, 1))
95*b9829059Sjoerg          return 1;
96*b9829059Sjoerg     if (test__mulosi4(0x7FFFFFFF, -1, 0x80000001, 0))
97*b9829059Sjoerg         return 1;
98*b9829059Sjoerg     if (test__mulosi4(-1, 0x7FFFFFFF, 0x80000001, 0))
99*b9829059Sjoerg         return 1;
100*b9829059Sjoerg     if (test__mulosi4(0x7FFFFFFF, 0, 0, 0))
101*b9829059Sjoerg         return 1;
102*b9829059Sjoerg     if (test__mulosi4(0, 0x7FFFFFFF, 0, 0))
103*b9829059Sjoerg         return 1;
104*b9829059Sjoerg     if (test__mulosi4(0x7FFFFFFF, 1, 0x7FFFFFFF, 0))
105*b9829059Sjoerg         return 1;
106*b9829059Sjoerg     if (test__mulosi4(1, 0x7FFFFFFF, 0x7FFFFFFF, 0))
107*b9829059Sjoerg         return 1;
108*b9829059Sjoerg      if (test__mulosi4(0x7FFFFFFF, 2, 0x80000001, 1))
109*b9829059Sjoerg          return 1;
110*b9829059Sjoerg      if (test__mulosi4(2, 0x7FFFFFFF, 0x80000001, 1))
111*b9829059Sjoerg          return 1;
112*b9829059Sjoerg 
113*b9829059Sjoerg      if (test__mulosi4(0x80000000, -2, 0x80000000, 1))
114*b9829059Sjoerg          return 1;
115*b9829059Sjoerg      if (test__mulosi4(-2, 0x80000000, 0x80000000, 1))
116*b9829059Sjoerg          return 1;
117*b9829059Sjoerg      if (test__mulosi4(0x80000000, -1, 0x80000000, 1))
118*b9829059Sjoerg          return 1;
119*b9829059Sjoerg      if (test__mulosi4(-1, 0x80000000, 0x80000000, 1))
120*b9829059Sjoerg          return 1;
121*b9829059Sjoerg     if (test__mulosi4(0x80000000, 0, 0, 0))
122*b9829059Sjoerg         return 1;
123*b9829059Sjoerg     if (test__mulosi4(0, 0x80000000, 0, 0))
124*b9829059Sjoerg         return 1;
125*b9829059Sjoerg     if (test__mulosi4(0x80000000, 1, 0x80000000, 0))
126*b9829059Sjoerg         return 1;
127*b9829059Sjoerg     if (test__mulosi4(1, 0x80000000, 0x80000000, 0))
128*b9829059Sjoerg         return 1;
129*b9829059Sjoerg      if (test__mulosi4(0x80000000, 2, 0x80000000, 1))
130*b9829059Sjoerg          return 1;
131*b9829059Sjoerg      if (test__mulosi4(2, 0x80000000, 0x80000000, 1))
132*b9829059Sjoerg          return 1;
133*b9829059Sjoerg 
134*b9829059Sjoerg      if (test__mulosi4(0x80000001, -2, 0x80000001, 1))
135*b9829059Sjoerg          return 1;
136*b9829059Sjoerg      if (test__mulosi4(-2, 0x80000001, 0x80000001, 1))
137*b9829059Sjoerg          return 1;
138*b9829059Sjoerg     if (test__mulosi4(0x80000001, -1, 0x7FFFFFFF, 0))
139*b9829059Sjoerg         return 1;
140*b9829059Sjoerg     if (test__mulosi4(-1, 0x80000001, 0x7FFFFFFF, 0))
141*b9829059Sjoerg         return 1;
142*b9829059Sjoerg     if (test__mulosi4(0x80000001, 0, 0, 0))
143*b9829059Sjoerg         return 1;
144*b9829059Sjoerg     if (test__mulosi4(0, 0x80000001, 0, 0))
145*b9829059Sjoerg         return 1;
146*b9829059Sjoerg     if (test__mulosi4(0x80000001, 1, 0x80000001, 0))
147*b9829059Sjoerg         return 1;
148*b9829059Sjoerg     if (test__mulosi4(1, 0x80000001, 0x80000001, 0))
149*b9829059Sjoerg         return 1;
150*b9829059Sjoerg      if (test__mulosi4(0x80000001, 2, 0x80000000, 1))
151*b9829059Sjoerg          return 1;
152*b9829059Sjoerg      if (test__mulosi4(2, 0x80000001, 0x80000000, 1))
153*b9829059Sjoerg          return 1;
154*b9829059Sjoerg 
155*b9829059Sjoerg     return 0;
156*b9829059Sjoerg }
157