1 1.1 joerg //===-- powisf2_test.cpp - Test __powisf2 ---------------------------------===// 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 __powisf2 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 #include <math.h> 17 1.1 joerg 18 1.1 joerg // Returns: a ^ b 19 1.1 joerg 20 1.1 joerg float __powisf2(float a, si_int b); 21 1.1 joerg 22 1.1 joerg int test__powisf2(float a, si_int b, float expected) 23 1.1 joerg { 24 1.1 joerg float x = __powisf2(a, b); 25 1.1 joerg int correct = (x == expected) && (signbit(x) == signbit(expected)); 26 1.1 joerg if (!correct) 27 1.1 joerg printf("error in __powisf2(%f, %d) = %f, expected %f\n", 28 1.1 joerg a, b, x, expected); 29 1.1 joerg return !correct; 30 1.1 joerg } 31 1.1 joerg 32 1.1 joerg int main() 33 1.1 joerg { 34 1.1 joerg if (test__powisf2(0, 0, 1)) 35 1.1 joerg return 1; 36 1.1 joerg if (test__powisf2(1, 0, 1)) 37 1.1 joerg return 1; 38 1.1 joerg if (test__powisf2(1.5, 0, 1)) 39 1.1 joerg return 1; 40 1.1 joerg if (test__powisf2(2, 0, 1)) 41 1.1 joerg return 1; 42 1.1 joerg if (test__powisf2(INFINITY, 0, 1)) 43 1.1 joerg return 1; 44 1.1 joerg 45 1.1 joerg if (test__powisf2(-0., 0, 1)) 46 1.1 joerg return 1; 47 1.1 joerg if (test__powisf2(-1, 0, 1)) 48 1.1 joerg return 1; 49 1.1 joerg if (test__powisf2(-1.5, 0, 1)) 50 1.1 joerg return 1; 51 1.1 joerg if (test__powisf2(-2, 0, 1)) 52 1.1 joerg return 1; 53 1.1 joerg if (test__powisf2(-INFINITY, 0, 1)) 54 1.1 joerg return 1; 55 1.1 joerg 56 1.1 joerg if (test__powisf2(0, 1, 0)) 57 1.1 joerg return 1; 58 1.1 joerg if (test__powisf2(0, 2, 0)) 59 1.1 joerg return 1; 60 1.1 joerg if (test__powisf2(0, 3, 0)) 61 1.1 joerg return 1; 62 1.1 joerg if (test__powisf2(0, 4, 0)) 63 1.1 joerg return 1; 64 1.1 joerg if (test__powisf2(0, 0x7FFFFFFE, 0)) 65 1.1 joerg return 1; 66 1.1 joerg if (test__powisf2(0, 0x7FFFFFFF, 0)) 67 1.1 joerg return 1; 68 1.1 joerg 69 1.1 joerg if (test__powisf2(-0., 1, -0.)) 70 1.1 joerg return 1; 71 1.1 joerg if (test__powisf2(-0., 2, 0)) 72 1.1 joerg return 1; 73 1.1 joerg if (test__powisf2(-0., 3, -0.)) 74 1.1 joerg return 1; 75 1.1 joerg if (test__powisf2(-0., 4, 0)) 76 1.1 joerg return 1; 77 1.1 joerg if (test__powisf2(-0., 0x7FFFFFFE, 0)) 78 1.1 joerg return 1; 79 1.1 joerg if (test__powisf2(-0., 0x7FFFFFFF, -0.)) 80 1.1 joerg return 1; 81 1.1 joerg 82 1.1 joerg if (test__powisf2(1, 1, 1)) 83 1.1 joerg return 1; 84 1.1 joerg if (test__powisf2(1, 2, 1)) 85 1.1 joerg return 1; 86 1.1 joerg if (test__powisf2(1, 3, 1)) 87 1.1 joerg return 1; 88 1.1 joerg if (test__powisf2(1, 4, 1)) 89 1.1 joerg return 1; 90 1.1 joerg if (test__powisf2(1, 0x7FFFFFFE, 1)) 91 1.1 joerg return 1; 92 1.1 joerg if (test__powisf2(1, 0x7FFFFFFF, 1)) 93 1.1 joerg return 1; 94 1.1 joerg 95 1.1 joerg if (test__powisf2(INFINITY, 1, INFINITY)) 96 1.1 joerg return 1; 97 1.1 joerg if (test__powisf2(INFINITY, 2, INFINITY)) 98 1.1 joerg return 1; 99 1.1 joerg if (test__powisf2(INFINITY, 3, INFINITY)) 100 1.1 joerg return 1; 101 1.1 joerg if (test__powisf2(INFINITY, 4, INFINITY)) 102 1.1 joerg return 1; 103 1.1 joerg if (test__powisf2(INFINITY, 0x7FFFFFFE, INFINITY)) 104 1.1 joerg return 1; 105 1.1 joerg if (test__powisf2(INFINITY, 0x7FFFFFFF, INFINITY)) 106 1.1 joerg return 1; 107 1.1 joerg 108 1.1 joerg if (test__powisf2(-INFINITY, 1, -INFINITY)) 109 1.1 joerg return 1; 110 1.1 joerg if (test__powisf2(-INFINITY, 2, INFINITY)) 111 1.1 joerg return 1; 112 1.1 joerg if (test__powisf2(-INFINITY, 3, -INFINITY)) 113 1.1 joerg return 1; 114 1.1 joerg if (test__powisf2(-INFINITY, 4, INFINITY)) 115 1.1 joerg return 1; 116 1.1 joerg if (test__powisf2(-INFINITY, 0x7FFFFFFE, INFINITY)) 117 1.1 joerg return 1; 118 1.1 joerg if (test__powisf2(-INFINITY, 0x7FFFFFFF, -INFINITY)) 119 1.1 joerg return 1; 120 1.1 joerg 121 1.1 joerg if (test__powisf2(0, -1, INFINITY)) 122 1.1 joerg return 1; 123 1.1 joerg if (test__powisf2(0, -2, INFINITY)) 124 1.1 joerg return 1; 125 1.1 joerg if (test__powisf2(0, -3, INFINITY)) 126 1.1 joerg return 1; 127 1.1 joerg if (test__powisf2(0, -4, INFINITY)) 128 1.1 joerg return 1; 129 1.1 joerg if (test__powisf2(0, 0x80000002, INFINITY)) 130 1.1 joerg return 1; 131 1.1 joerg if (test__powisf2(0, 0x80000001, INFINITY)) 132 1.1 joerg return 1; 133 1.1 joerg if (test__powisf2(0, 0x80000000, INFINITY)) 134 1.1 joerg return 1; 135 1.1 joerg 136 1.1 joerg if (test__powisf2(-0., -1, -INFINITY)) 137 1.1 joerg return 1; 138 1.1 joerg if (test__powisf2(-0., -2, INFINITY)) 139 1.1 joerg return 1; 140 1.1 joerg if (test__powisf2(-0., -3, -INFINITY)) 141 1.1 joerg return 1; 142 1.1 joerg if (test__powisf2(-0., -4, INFINITY)) 143 1.1 joerg return 1; 144 1.1 joerg if (test__powisf2(-0., 0x80000002, INFINITY)) 145 1.1 joerg return 1; 146 1.1 joerg if (test__powisf2(-0., 0x80000001, -INFINITY)) 147 1.1 joerg return 1; 148 1.1 joerg if (test__powisf2(-0., 0x80000000, INFINITY)) 149 1.1 joerg return 1; 150 1.1 joerg 151 1.1 joerg if (test__powisf2(1, -1, 1)) 152 1.1 joerg return 1; 153 1.1 joerg if (test__powisf2(1, -2, 1)) 154 1.1 joerg return 1; 155 1.1 joerg if (test__powisf2(1, -3, 1)) 156 1.1 joerg return 1; 157 1.1 joerg if (test__powisf2(1, -4, 1)) 158 1.1 joerg return 1; 159 1.1 joerg if (test__powisf2(1, 0x80000002, 1)) 160 1.1 joerg return 1; 161 1.1 joerg if (test__powisf2(1, 0x80000001, 1)) 162 1.1 joerg return 1; 163 1.1 joerg if (test__powisf2(1, 0x80000000, 1)) 164 1.1 joerg return 1; 165 1.1 joerg 166 1.1 joerg if (test__powisf2(INFINITY, -1, 0)) 167 1.1 joerg return 1; 168 1.1 joerg if (test__powisf2(INFINITY, -2, 0)) 169 1.1 joerg return 1; 170 1.1 joerg if (test__powisf2(INFINITY, -3, 0)) 171 1.1 joerg return 1; 172 1.1 joerg if (test__powisf2(INFINITY, -4, 0)) 173 1.1 joerg return 1; 174 1.1 joerg if (test__powisf2(INFINITY, 0x80000002, 0)) 175 1.1 joerg return 1; 176 1.1 joerg if (test__powisf2(INFINITY, 0x80000001, 0)) 177 1.1 joerg return 1; 178 1.1 joerg if (test__powisf2(INFINITY, 0x80000000, 0)) 179 1.1 joerg return 1; 180 1.1 joerg 181 1.1 joerg if (test__powisf2(-INFINITY, -1, -0.)) 182 1.1 joerg return 1; 183 1.1 joerg if (test__powisf2(-INFINITY, -2, 0)) 184 1.1 joerg return 1; 185 1.1 joerg if (test__powisf2(-INFINITY, -3, -0.)) 186 1.1 joerg return 1; 187 1.1 joerg if (test__powisf2(-INFINITY, -4, 0)) 188 1.1 joerg return 1; 189 1.1 joerg if (test__powisf2(-INFINITY, 0x80000002, 0)) 190 1.1 joerg return 1; 191 1.1 joerg if (test__powisf2(-INFINITY, 0x80000001, -0.)) 192 1.1 joerg return 1; 193 1.1 joerg if (test__powisf2(-INFINITY, 0x80000000, 0)) 194 1.1 joerg return 1; 195 1.1 joerg 196 1.1 joerg if (test__powisf2(2, 10, 1024.)) 197 1.1 joerg return 1; 198 1.1 joerg if (test__powisf2(-2, 10, 1024.)) 199 1.1 joerg return 1; 200 1.1 joerg if (test__powisf2(2, -10, 1/1024.)) 201 1.1 joerg return 1; 202 1.1 joerg if (test__powisf2(-2, -10, 1/1024.)) 203 1.1 joerg return 1; 204 1.1 joerg 205 1.1 joerg if (test__powisf2(2, 19, 524288.)) 206 1.1 joerg return 1; 207 1.1 joerg if (test__powisf2(-2, 19, -524288.)) 208 1.1 joerg return 1; 209 1.1 joerg if (test__powisf2(2, -19, 1/524288.)) 210 1.1 joerg return 1; 211 1.1 joerg if (test__powisf2(-2, -19, -1/524288.)) 212 1.1 joerg return 1; 213 1.1 joerg 214 1.1 joerg if (test__powisf2(2, 31, 2147483648.)) 215 1.1 joerg return 1; 216 1.1 joerg if (test__powisf2(-2, 31, -2147483648.)) 217 1.1 joerg return 1; 218 1.1 joerg if (test__powisf2(2, -31, 1/2147483648.)) 219 1.1 joerg return 1; 220 1.1 joerg if (test__powisf2(-2, -31, -1/2147483648.)) 221 1.1 joerg return 1; 222 1.1 joerg 223 1.1 joerg return 0; 224 1.1 joerg } 225