1 1.1 joerg //===-- divdi3_test.c - Test __divdi3 -------------------------------------===// 2 1.1 joerg // 3 1.1 joerg // The LLVM Compiler Infrastructure 4 1.1 joerg // 5 1.1 joerg // This file is dual licensed under the MIT and the University of Illinois Open 6 1.1 joerg // Source Licenses. See LICENSE.TXT for details. 7 1.1 joerg // 8 1.1 joerg //===----------------------------------------------------------------------===// 9 1.1 joerg // 10 1.1 joerg // This file tests __divdi3 for the compiler_rt library. 11 1.1 joerg // 12 1.1 joerg //===----------------------------------------------------------------------===// 13 1.1 joerg 14 1.1 joerg #include "int_lib.h" 15 1.1 joerg #include <stdio.h> 16 1.1 joerg 17 1.1 joerg // Returns: a / b 18 1.1 joerg 19 1.1 joerg di_int __divdi3(di_int a, di_int b); 20 1.1 joerg 21 1.1 joerg int test__divdi3(di_int a, di_int b, di_int expected) 22 1.1 joerg { 23 1.1 joerg di_int x = __divdi3(a, b); 24 1.1 joerg if (x != expected) 25 1.1 joerg printf("error in __divdi3: %lld / %lld = %lld, expected %lld\n", 26 1.1 joerg a, b, x, expected); 27 1.1 joerg return x != expected; 28 1.1 joerg } 29 1.1 joerg 30 1.1 joerg char assumption_1[sizeof(di_int) == 2*sizeof(si_int)] = {0}; 31 1.1 joerg 32 1.1 joerg int main() 33 1.1 joerg { 34 1.1 joerg if (test__divdi3(0, 1, 0)) 35 1.1 joerg return 1; 36 1.1 joerg if (test__divdi3(0, -1, 0)) 37 1.1 joerg return 1; 38 1.1 joerg 39 1.1 joerg if (test__divdi3(2, 1, 2)) 40 1.1 joerg return 1; 41 1.1 joerg if (test__divdi3(2, -1, -2)) 42 1.1 joerg return 1; 43 1.1 joerg if (test__divdi3(-2, 1, -2)) 44 1.1 joerg return 1; 45 1.1 joerg if (test__divdi3(-2, -1, 2)) 46 1.1 joerg return 1; 47 1.1 joerg 48 1.1 joerg if (test__divdi3(0x8000000000000000LL, 1, 0x8000000000000000LL)) 49 1.1 joerg return 1; 50 1.1 joerg if (test__divdi3(0x8000000000000000LL, -1, 0x8000000000000000LL)) 51 1.1 joerg return 1; 52 1.1 joerg if (test__divdi3(0x8000000000000000LL, -2, 0x4000000000000000LL)) 53 1.1 joerg return 1; 54 1.1 joerg if (test__divdi3(0x8000000000000000LL, 2, 0xC000000000000000LL)) 55 1.1 joerg return 1; 56 1.1 joerg 57 1.1 joerg return 0; 58 1.1 joerg } 59