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}