master
 1const std = @import("std");
 2const builtin = @import("builtin");
 3const arch = builtin.cpu.arch;
 4const common = @import("common.zig");
 5
 6pub const panic = common.panic;
 7
 8comptime {
 9    @export(&__fabsh, .{ .name = "__fabsh", .linkage = common.linkage, .visibility = common.visibility });
10    @export(&fabsf, .{ .name = "fabsf", .linkage = common.linkage, .visibility = common.visibility });
11    @export(&fabs, .{ .name = "fabs", .linkage = common.linkage, .visibility = common.visibility });
12    @export(&__fabsx, .{ .name = "__fabsx", .linkage = common.linkage, .visibility = common.visibility });
13    if (common.want_ppc_abi) {
14        @export(&fabsq, .{ .name = "fabsf128", .linkage = common.linkage, .visibility = common.visibility });
15    }
16    @export(&fabsq, .{ .name = "fabsq", .linkage = common.linkage, .visibility = common.visibility });
17    @export(&fabsl, .{ .name = "fabsl", .linkage = common.linkage, .visibility = common.visibility });
18}
19
20pub fn __fabsh(a: f16) callconv(.c) f16 {
21    return generic_fabs(a);
22}
23
24pub fn fabsf(a: f32) callconv(.c) f32 {
25    return generic_fabs(a);
26}
27
28pub fn fabs(a: f64) callconv(.c) f64 {
29    return generic_fabs(a);
30}
31
32pub fn __fabsx(a: f80) callconv(.c) f80 {
33    return generic_fabs(a);
34}
35
36pub fn fabsq(a: f128) callconv(.c) f128 {
37    return generic_fabs(a);
38}
39
40pub fn fabsl(x: c_longdouble) callconv(.c) c_longdouble {
41    switch (@typeInfo(c_longdouble).float.bits) {
42        16 => return __fabsh(x),
43        32 => return fabsf(x),
44        64 => return fabs(x),
45        80 => return __fabsx(x),
46        128 => return fabsq(x),
47        else => @compileError("unreachable"),
48    }
49}
50
51inline fn generic_fabs(x: anytype) @TypeOf(x) {
52    const T = @TypeOf(x);
53    const TBits = std.meta.Int(.unsigned, @typeInfo(T).float.bits);
54    const float_bits: TBits = @bitCast(x);
55    const remove_sign = ~@as(TBits, 0) >> 1;
56    return @bitCast(float_bits & remove_sign);
57}