1 //===-- udivmodsi4_test.c - Test __udivmodsi4 -----------------------------===//
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 __udivmodsi4 for the compiler_rt library.
11 //
12 //===----------------------------------------------------------------------===//
13 
14 #include "int_lib.h"
15 #include <stdio.h>
16 
17 // Returns: a / b
18 
19 extern COMPILER_RT_ABI su_int __udivmodsi4(su_int a, su_int b, su_int* rem);
20 
test__udivmodsi4(su_int a,su_int b,su_int expected_result,su_int expected_rem)21 int test__udivmodsi4(su_int a, su_int b,
22 						su_int expected_result, su_int expected_rem)
23 {
24 	su_int rem;
25     su_int result = __udivmodsi4(a, b, &rem);
26     if (result != expected_result) {
27         printf("error in __udivmodsi4: %u / %u = %u, expected %u\n",
28                a, b, result, expected_result);
29 		return 1;
30 	}
31     if (rem != expected_rem) {
32         printf("error in __udivmodsi4: %u mod %u = %u, expected %u\n",
33                a, b, rem, expected_rem);
34 		return 1;
35 	}
36 
37     return 0;
38 }
39 
40 
main()41 int main()
42 {
43     if (test__udivmodsi4(0, 1, 0, 0))
44         return 1;
45 
46     if (test__udivmodsi4(2, 1, 2, 0))
47         return 1;
48 
49 	if (test__udivmodsi4(19, 5, 3, 4))
50         return 1;
51 
52 	if (test__udivmodsi4(0x80000000, 8, 0x10000000, 0))
53         return 1;
54 
55  	if (test__udivmodsi4(0x80000003, 8, 0x10000000, 3))
56         return 1;
57 
58 	return 0;
59 }
60