blob: 1af93bc77c80e2c97020d2dd63b17a421a86293e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
// Ported from:
//
// https://github.com/llvm/llvm-project/commit/d674d96bc56c0f377879d01c9d8dfdaaa7859cdb/compiler-rt/test/builtins/Unit/divsf3_test.c
const __divsf3 = @import("divsf3.zig").__divsf3;
const testing = @import("std").testing;
fn compareResultF(result: f32, expected: u32) bool {
const rep: u32 = @bitCast(result);
if (rep == expected) {
return true;
}
// test other possible NaN representation(signal NaN)
else if (expected == 0x7fc00000) {
if ((rep & 0x7f800000) == 0x7f800000 and
(rep & 0x7fffff) > 0)
{
return true;
}
}
return false;
}
fn test__divsf3(a: f32, b: f32, expected: u32) !void {
const x = __divsf3(a, b);
const ret = compareResultF(x, expected);
try testing.expect(ret == true);
}
test "divsf3" {
try test__divsf3(1.0, 3.0, 0x3EAAAAAB);
try test__divsf3(2.3509887e-38, 2.0, 0x00800000);
try test__divsf3(1.0, 0x1.fffffep-1, 0x3f800001);
}
|