1 1.1 joerg //===-- negdi2_test.c - Test __negdi2 -------------------------------------===// 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 __negdi2 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 18 1.1 joerg 19 1.1 joerg di_int __negdi2(di_int a); 20 1.1 joerg 21 1.1 joerg int test__negdi2(di_int a, di_int expected) 22 1.1 joerg { 23 1.1 joerg di_int x = __negdi2(a); 24 1.1 joerg if (x != expected) 25 1.1 joerg printf("error in __negdi2: -0x%llX = 0x%llX, expected 0x%llX\n", 26 1.1 joerg a, 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__negdi2(0, 0)) 35 1.1 joerg return 1; 36 1.1 joerg if (test__negdi2(1, -1)) 37 1.1 joerg return 1; 38 1.1 joerg if (test__negdi2(-1, 1)) 39 1.1 joerg return 1; 40 1.1 joerg if (test__negdi2(2, -2)) 41 1.1 joerg return 1; 42 1.1 joerg if (test__negdi2(-2, 2)) 43 1.1 joerg return 1; 44 1.1 joerg if (test__negdi2(3, -3)) 45 1.1 joerg return 1; 46 1.1 joerg if (test__negdi2(-3, 3)) 47 1.1 joerg return 1; 48 1.1 joerg if (test__negdi2(0x00000000FFFFFFFELL, 0xFFFFFFFF00000002LL)) 49 1.1 joerg return 1; 50 1.1 joerg if (test__negdi2(0xFFFFFFFF00000002LL, 0x00000000FFFFFFFELL)) 51 1.1 joerg return 1; 52 1.1 joerg if (test__negdi2(0x00000000FFFFFFFFLL, 0xFFFFFFFF00000001LL)) 53 1.1 joerg return 1; 54 1.1 joerg if (test__negdi2(0xFFFFFFFF00000001LL, 0x00000000FFFFFFFFLL)) 55 1.1 joerg return 1; 56 1.1 joerg if (test__negdi2(0x0000000100000000LL, 0xFFFFFFFF00000000LL)) 57 1.1 joerg return 1; 58 1.1 joerg if (test__negdi2(0xFFFFFFFF00000000LL, 0x0000000100000000LL)) 59 1.1 joerg return 1; 60 1.1 joerg if (test__negdi2(0x0000000200000000LL, 0xFFFFFFFE00000000LL)) 61 1.1 joerg return 1; 62 1.1 joerg if (test__negdi2(0xFFFFFFFE00000000LL, 0x0000000200000000LL)) 63 1.1 joerg return 1; 64 1.1 joerg if (test__negdi2(0x0000000300000000LL, 0xFFFFFFFD00000000LL)) 65 1.1 joerg return 1; 66 1.1 joerg if (test__negdi2(0xFFFFFFFD00000000LL, 0x0000000300000000LL)) 67 1.1 joerg return 1; 68 1.1 joerg if (test__negdi2(0x8000000000000000LL, 0x8000000000000000LL)) 69 1.1 joerg return 1; 70 1.1 joerg if (test__negdi2(0x8000000000000001LL, 0x7FFFFFFFFFFFFFFFLL)) 71 1.1 joerg return 1; 72 1.1 joerg if (test__negdi2(0x7FFFFFFFFFFFFFFFLL, 0x8000000000000001LL)) 73 1.1 joerg return 1; 74 1.1 joerg if (test__negdi2(0xFFFFFFFE00000000LL, 0x0000000200000000LL)) 75 1.1 joerg return 1; 76 1.1 joerg if (test__negdi2(0x0000000200000000LL, 0xFFFFFFFE00000000LL)) 77 1.1 joerg return 1; 78 1.1 joerg if (test__negdi2(0xFFFFFFFF00000000LL, 0x0000000100000000LL)) 79 1.1 joerg return 1; 80 1.1 joerg if (test__negdi2(0x0000000100000000LL, 0xFFFFFFFF00000000LL)) 81 1.1 joerg return 1; 82 1.1 joerg 83 1.1 joerg return 0; 84 1.1 joerg } 85