diff options
| author | LemonBoy <thatlemon@gmail.com> | 2020-01-07 17:44:20 +0100 |
|---|---|---|
| committer | Andrew Kelley <andrew@ziglang.org> | 2020-01-07 13:42:47 -0500 |
| commit | e81b505960b106a042e4cb890971ba365a5ef180 (patch) | |
| tree | 751dc190a6b9c95a9cfd33057657e2a55b94b691 /lib/std/special | |
| parent | 4e4ba6c3e1273fda8137f9f7e26325051f92bfa4 (diff) | |
| download | zig-e81b505960b106a042e4cb890971ba365a5ef180.tar.gz zig-e81b505960b106a042e4cb890971ba365a5ef180.zip | |
Use the correct calling convention for AEABI intrinsics
Diffstat (limited to 'lib/std/special')
26 files changed, 194 insertions, 60 deletions
diff --git a/lib/std/special/compiler_rt.zig b/lib/std/special/compiler_rt.zig index 7a55300583..efa21d6cd7 100644 --- a/lib/std/special/compiler_rt.zig +++ b/lib/std/special/compiler_rt.zig @@ -181,62 +181,62 @@ comptime { @export("__aeabi_memcmp4", __aeabi_memcmp, linkage); @export("__aeabi_memcmp8", __aeabi_memcmp, linkage); - @export("__aeabi_f2d", @import("compiler_rt/extendXfYf2.zig").__extendsfdf2, linkage); - @export("__aeabi_i2d", @import("compiler_rt/floatsiXf.zig").__floatsidf, linkage); - @export("__aeabi_l2d", @import("compiler_rt/floatdidf.zig").__floatdidf, linkage); - @export("__aeabi_ui2d", @import("compiler_rt/floatunsidf.zig").__floatunsidf, linkage); - @export("__aeabi_ul2d", @import("compiler_rt/floatundidf.zig").__floatundidf, linkage); - @export("__aeabi_ui2f", @import("compiler_rt/floatunsisf.zig").__floatunsisf, linkage); - @export("__aeabi_ul2f", @import("compiler_rt/floatundisf.zig").__floatundisf, linkage); + @export("__aeabi_f2d", @import("compiler_rt/extendXfYf2.zig").__aeabi_f2d, linkage); + @export("__aeabi_i2d", @import("compiler_rt/floatsiXf.zig").__aeabi_i2d, linkage); + @export("__aeabi_l2d", @import("compiler_rt/floatdidf.zig").__aeabi_l2d, linkage); + @export("__aeabi_ui2d", @import("compiler_rt/floatunsidf.zig").__aeabi_ui2d, linkage); + @export("__aeabi_ul2d", @import("compiler_rt/floatundidf.zig").__aeabi_ul2d, linkage); + @export("__aeabi_ui2f", @import("compiler_rt/floatunsisf.zig").__aeabi_ui2f, linkage); + @export("__aeabi_ul2f", @import("compiler_rt/floatundisf.zig").__aeabi_ul2f, linkage); - @export("__aeabi_fneg", @import("compiler_rt/negXf2.zig").__negsf2, linkage); - @export("__aeabi_dneg", @import("compiler_rt/negXf2.zig").__negdf2, linkage); + @export("__aeabi_fneg", @import("compiler_rt/negXf2.zig").__aeabi_fneg, linkage); + @export("__aeabi_dneg", @import("compiler_rt/negXf2.zig").__aeabi_dneg, linkage); - @export("__aeabi_fmul", @import("compiler_rt/mulXf3.zig").__mulsf3, linkage); - @export("__aeabi_dmul", @import("compiler_rt/mulXf3.zig").__muldf3, linkage); + @export("__aeabi_fmul", @import("compiler_rt/mulXf3.zig").__aeabi_fmul, linkage); + @export("__aeabi_dmul", @import("compiler_rt/mulXf3.zig").__aeabi_dmul, linkage); - @export("__aeabi_d2h", @import("compiler_rt/truncXfYf2.zig").__truncdfhf2, linkage); + @export("__aeabi_d2h", @import("compiler_rt/truncXfYf2.zig").__aeabi_d2h, linkage); - @export("__aeabi_f2ulz", @import("compiler_rt/fixunssfdi.zig").__fixunssfdi, linkage); - @export("__aeabi_d2ulz", @import("compiler_rt/fixunsdfdi.zig").__fixunsdfdi, linkage); + @export("__aeabi_f2ulz", @import("compiler_rt/fixunssfdi.zig").__aeabi_f2ulz, linkage); + @export("__aeabi_d2ulz", @import("compiler_rt/fixunsdfdi.zig").__aeabi_d2ulz, linkage); - @export("__aeabi_f2lz", @import("compiler_rt/fixsfdi.zig").__fixsfdi, linkage); - @export("__aeabi_d2lz", @import("compiler_rt/fixdfdi.zig").__fixdfdi, linkage); + @export("__aeabi_f2lz", @import("compiler_rt/fixsfdi.zig").__aeabi_f2lz, linkage); + @export("__aeabi_d2lz", @import("compiler_rt/fixdfdi.zig").__aeabi_d2lz, linkage); - @export("__aeabi_d2uiz", @import("compiler_rt/fixunsdfsi.zig").__fixunsdfsi, linkage); + @export("__aeabi_d2uiz", @import("compiler_rt/fixunsdfsi.zig").__aeabi_d2uiz, linkage); - @export("__aeabi_h2f", @import("compiler_rt/extendXfYf2.zig").__extendhfsf2, linkage); - @export("__aeabi_f2h", @import("compiler_rt/truncXfYf2.zig").__truncsfhf2, linkage); + @export("__aeabi_h2f", @import("compiler_rt/extendXfYf2.zig").__aeabi_h2f, linkage); + @export("__aeabi_f2h", @import("compiler_rt/truncXfYf2.zig").__aeabi_f2h, linkage); - @export("__aeabi_i2f", @import("compiler_rt/floatsiXf.zig").__floatsisf, linkage); - @export("__aeabi_d2f", @import("compiler_rt/truncXfYf2.zig").__truncdfsf2, linkage); + @export("__aeabi_i2f", @import("compiler_rt/floatsiXf.zig").__aeabi_i2f, linkage); + @export("__aeabi_d2f", @import("compiler_rt/truncXfYf2.zig").__aeabi_d2f, linkage); - @export("__aeabi_fadd", @import("compiler_rt/addXf3.zig").__addsf3, linkage); - @export("__aeabi_dadd", @import("compiler_rt/addXf3.zig").__adddf3, linkage); - @export("__aeabi_fsub", @import("compiler_rt/addXf3.zig").__subsf3, linkage); - @export("__aeabi_dsub", @import("compiler_rt/addXf3.zig").__subdf3, linkage); + @export("__aeabi_fadd", @import("compiler_rt/addXf3.zig").__aeabi_fadd, linkage); + @export("__aeabi_dadd", @import("compiler_rt/addXf3.zig").__aeabi_dadd, linkage); + @export("__aeabi_fsub", @import("compiler_rt/addXf3.zig").__aeabi_fsub, linkage); + @export("__aeabi_dsub", @import("compiler_rt/addXf3.zig").__aeabi_dsub, linkage); - @export("__aeabi_f2uiz", @import("compiler_rt/fixunssfsi.zig").__fixunssfsi, linkage); + @export("__aeabi_f2uiz", @import("compiler_rt/fixunssfsi.zig").__aeabi_f2uiz, linkage); - @export("__aeabi_f2iz", @import("compiler_rt/fixsfsi.zig").__fixsfsi, linkage); - @export("__aeabi_d2iz", @import("compiler_rt/fixdfsi.zig").__fixdfsi, linkage); + @export("__aeabi_f2iz", @import("compiler_rt/fixsfsi.zig").__aeabi_f2iz, linkage); + @export("__aeabi_d2iz", @import("compiler_rt/fixdfsi.zig").__aeabi_d2iz, linkage); - @export("__aeabi_fdiv", @import("compiler_rt/divsf3.zig").__divsf3, linkage); - @export("__aeabi_ddiv", @import("compiler_rt/divdf3.zig").__divdf3, linkage); + @export("__aeabi_fdiv", @import("compiler_rt/divsf3.zig").__aeabi_fdiv, linkage); + @export("__aeabi_ddiv", @import("compiler_rt/divdf3.zig").__aeabi_ddiv, linkage); @export("__aeabi_fcmpeq", @import("compiler_rt/arm/aeabi_fcmp.zig").__aeabi_fcmpeq, linkage); @export("__aeabi_fcmplt", @import("compiler_rt/arm/aeabi_fcmp.zig").__aeabi_fcmplt, linkage); @export("__aeabi_fcmple", @import("compiler_rt/arm/aeabi_fcmp.zig").__aeabi_fcmple, linkage); @export("__aeabi_fcmpge", @import("compiler_rt/arm/aeabi_fcmp.zig").__aeabi_fcmpge, linkage); @export("__aeabi_fcmpgt", @import("compiler_rt/arm/aeabi_fcmp.zig").__aeabi_fcmpgt, linkage); - @export("__aeabi_fcmpun", @import("compiler_rt/comparesf2.zig").__unordsf2, linkage); + @export("__aeabi_fcmpun", @import("compiler_rt/comparesf2.zig").__aeabi_fcmpun, linkage); @export("__aeabi_dcmpeq", @import("compiler_rt/arm/aeabi_dcmp.zig").__aeabi_dcmpeq, linkage); @export("__aeabi_dcmplt", @import("compiler_rt/arm/aeabi_dcmp.zig").__aeabi_dcmplt, linkage); @export("__aeabi_dcmple", @import("compiler_rt/arm/aeabi_dcmp.zig").__aeabi_dcmple, linkage); @export("__aeabi_dcmpge", @import("compiler_rt/arm/aeabi_dcmp.zig").__aeabi_dcmpge, linkage); @export("__aeabi_dcmpgt", @import("compiler_rt/arm/aeabi_dcmp.zig").__aeabi_dcmpgt, linkage); - @export("__aeabi_dcmpun", @import("compiler_rt/comparedf2.zig").__unorddf2, linkage); + @export("__aeabi_dcmpun", @import("compiler_rt/comparedf2.zig").__aeabi_dcmpun, linkage); } if (builtin.os == .windows) { // Default stack-probe functions emitted by LLVM diff --git a/lib/std/special/compiler_rt/addXf3.zig b/lib/std/special/compiler_rt/addXf3.zig index ac38e1c8cd..4294752baa 100644 --- a/lib/std/special/compiler_rt/addXf3.zig +++ b/lib/std/special/compiler_rt/addXf3.zig @@ -33,6 +33,26 @@ pub fn __subtf3(a: f128, b: f128) callconv(.C) f128 { return addXf3(f128, a, neg_b); } +pub fn __aeabi_fadd(a: f32, b: f32) callconv(.AAPCS) f32 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __addsf3, .{ a, b }); +} + +pub fn __aeabi_dadd(a: f64, b: f64) callconv(.AAPCS) f64 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __adddf3, .{ a, b }); +} + +pub fn __aeabi_fsub(a: f32, b: f32) callconv(.AAPCS) f32 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __subsf3, .{ a, b }); +} + +pub fn __aeabi_dsub(a: f64, b: f64) callconv(.AAPCS) f64 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __subdf3, .{ a, b }); +} + // TODO: restore inline keyword, see: https://github.com/ziglang/zig/issues/2154 fn normalize(comptime T: type, significand: *@IntType(false, T.bit_count)) i32 { const Z = @IntType(false, T.bit_count); diff --git a/lib/std/special/compiler_rt/arm/aeabi_dcmp.zig b/lib/std/special/compiler_rt/arm/aeabi_dcmp.zig index d75c343fbb..a8ed182901 100644 --- a/lib/std/special/compiler_rt/arm/aeabi_dcmp.zig +++ b/lib/std/special/compiler_rt/arm/aeabi_dcmp.zig @@ -2,8 +2,6 @@ // // https://github.com/llvm/llvm-project/commit/d674d96bc56c0f377879d01c9d8dfdaaa7859cdb/compiler-rt/lib/builtins/arm/aeabi_dcmp.S -const compiler_rt_armhf_target = false; // TODO - const ConditionalOperator = enum { Eq, Lt, @@ -42,23 +40,12 @@ pub fn __aeabi_dcmpgt() callconv(.Naked) noreturn { unreachable; } -inline fn convert_dcmp_args_to_df2_args() void { - asm volatile ( - \\ vmov d0, r0, r1 - \\ vmov d1, r2, r3 - ); -} - fn aeabi_dcmp(comptime cond: ConditionalOperator) void { @setRuntimeSafety(false); asm volatile ( \\ push { r4, lr } ); - if (compiler_rt_armhf_target) { - convert_dcmp_args_to_df2_args(); - } - switch (cond) { .Eq => asm volatile ( \\ bl __eqdf2 diff --git a/lib/std/special/compiler_rt/arm/aeabi_fcmp.zig b/lib/std/special/compiler_rt/arm/aeabi_fcmp.zig index bf36e78ad2..0b4c0f0d41 100644 --- a/lib/std/special/compiler_rt/arm/aeabi_fcmp.zig +++ b/lib/std/special/compiler_rt/arm/aeabi_fcmp.zig @@ -2,8 +2,6 @@ // // https://github.com/llvm/llvm-project/commit/d674d96bc56c0f377879d01c9d8dfdaaa7859cdb/compiler-rt/lib/builtins/arm/aeabi_fcmp.S -const compiler_rt_armhf_target = false; // TODO - const ConditionalOperator = enum { Eq, Lt, @@ -42,23 +40,12 @@ pub fn __aeabi_fcmpgt() callconv(.Naked) noreturn { unreachable; } -inline fn convert_fcmp_args_to_sf2_args() void { - asm volatile ( - \\ vmov s0, r0 - \\ vmov s1, r1 - ); -} - fn aeabi_fcmp(comptime cond: ConditionalOperator) void { @setRuntimeSafety(false); asm volatile ( \\ push { r4, lr } ); - if (compiler_rt_armhf_target) { - convert_fcmp_args_to_sf2_args(); - } - switch (cond) { .Eq => asm volatile ( \\ bl __eqsf2 diff --git a/lib/std/special/compiler_rt/comparedf2.zig b/lib/std/special/compiler_rt/comparedf2.zig index b6e08c49f4..98cca106f7 100644 --- a/lib/std/special/compiler_rt/comparedf2.zig +++ b/lib/std/special/compiler_rt/comparedf2.zig @@ -117,6 +117,11 @@ pub fn __gtdf2(a: fp_t, b: fp_t) callconv(.C) c_int { return __gedf2(a, b); } +pub fn __aeabi_dcmpun(a: fp_t, b: fp_t) callconv(.AAPCS) c_int { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __unorddf2, .{ a, b }); +} + test "import comparedf2" { _ = @import("comparedf2_test.zig"); } diff --git a/lib/std/special/compiler_rt/comparesf2.zig b/lib/std/special/compiler_rt/comparesf2.zig index fdb5737ad3..bd881af2a1 100644 --- a/lib/std/special/compiler_rt/comparesf2.zig +++ b/lib/std/special/compiler_rt/comparesf2.zig @@ -117,6 +117,11 @@ pub fn __gtsf2(a: fp_t, b: fp_t) callconv(.C) c_int { return __gesf2(a, b); } +pub fn __aeabi_fcmpun(a: fp_t, b: fp_t) callconv(.AAPCS) c_int { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __unordsf2, .{ a, b }); +} + test "import comparesf2" { _ = @import("comparesf2_test.zig"); } diff --git a/lib/std/special/compiler_rt/divdf3.zig b/lib/std/special/compiler_rt/divdf3.zig index a8afd4a3a6..f0c0d1247c 100644 --- a/lib/std/special/compiler_rt/divdf3.zig +++ b/lib/std/special/compiler_rt/divdf3.zig @@ -323,6 +323,11 @@ fn normalize(comptime T: type, significand: *@IntType(false, T.bit_count)) i32 { return 1 - shift; } +pub fn __aeabi_ddiv(a: f64, b: f64) callconv(.AAPCS) f64 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __divdf3, .{ a, b }); +} + test "import divdf3" { _ = @import("divdf3_test.zig"); } diff --git a/lib/std/special/compiler_rt/divsf3.zig b/lib/std/special/compiler_rt/divsf3.zig index ea882b4927..e51f94e19d 100644 --- a/lib/std/special/compiler_rt/divsf3.zig +++ b/lib/std/special/compiler_rt/divsf3.zig @@ -196,6 +196,11 @@ fn normalize(comptime T: type, significand: *@IntType(false, T.bit_count)) i32 { return 1 - shift; } +pub fn __aeabi_fdiv(a: f32, b: f32) callconv(.AAPCS) f32 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __divsf3, .{ a, b }); +} + test "import divsf3" { _ = @import("divsf3_test.zig"); } diff --git a/lib/std/special/compiler_rt/extendXfYf2.zig b/lib/std/special/compiler_rt/extendXfYf2.zig index 10227043aa..4e63d93ac5 100644 --- a/lib/std/special/compiler_rt/extendXfYf2.zig +++ b/lib/std/special/compiler_rt/extendXfYf2.zig @@ -18,6 +18,16 @@ pub fn __extendhfsf2(a: u16) callconv(.C) f32 { return @call(.{ .modifier = .always_inline }, extendXfYf2, .{ f32, f16, a }); } +pub fn __aeabi_h2f(arg: u16) callconv(.AAPCS) f32 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __extendhfsf2, .{arg}); +} + +pub fn __aeabi_f2d(arg: f32) callconv(.AAPCS) f64 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __extendsfdf2, .{arg}); +} + const CHAR_BIT = 8; fn extendXfYf2(comptime dst_t: type, comptime src_t: type, a: @IntType(false, @typeInfo(src_t).Float.bits)) dst_t { diff --git a/lib/std/special/compiler_rt/fixdfdi.zig b/lib/std/special/compiler_rt/fixdfdi.zig index fb3b31d6e8..11b5009129 100644 --- a/lib/std/special/compiler_rt/fixdfdi.zig +++ b/lib/std/special/compiler_rt/fixdfdi.zig @@ -6,6 +6,11 @@ pub fn __fixdfdi(a: f64) callconv(.C) i64 { return fixint(f64, i64, a); } +pub fn __aeabi_d2lz(arg: f64) callconv(.AAPCS) i64 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __fixdfdi, .{arg}); +} + test "import fixdfdi" { _ = @import("fixdfdi_test.zig"); } diff --git a/lib/std/special/compiler_rt/fixdfsi.zig b/lib/std/special/compiler_rt/fixdfsi.zig index de21c86e43..8a6d8da342 100644 --- a/lib/std/special/compiler_rt/fixdfsi.zig +++ b/lib/std/special/compiler_rt/fixdfsi.zig @@ -6,6 +6,11 @@ pub fn __fixdfsi(a: f64) callconv(.C) i32 { return fixint(f64, i32, a); } +pub fn __aeabi_d2iz(a: f64) callconv(.AAPCS) i32 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __fixdfsi, .{a}); +} + test "import fixdfsi" { _ = @import("fixdfsi_test.zig"); } diff --git a/lib/std/special/compiler_rt/fixsfdi.zig b/lib/std/special/compiler_rt/fixsfdi.zig index d3aaf9d470..d0d958cdd6 100644 --- a/lib/std/special/compiler_rt/fixsfdi.zig +++ b/lib/std/special/compiler_rt/fixsfdi.zig @@ -6,6 +6,11 @@ pub fn __fixsfdi(a: f32) callconv(.C) i64 { return fixint(f32, i64, a); } +pub fn __aeabi_f2lz(arg: f32) callconv(.AAPCS) i64 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __fixsfdi, .{arg}); +} + test "import fixsfdi" { _ = @import("fixsfdi_test.zig"); } diff --git a/lib/std/special/compiler_rt/fixsfsi.zig b/lib/std/special/compiler_rt/fixsfsi.zig index 81aa01dfa1..84395d0fa6 100644 --- a/lib/std/special/compiler_rt/fixsfsi.zig +++ b/lib/std/special/compiler_rt/fixsfsi.zig @@ -6,6 +6,11 @@ pub fn __fixsfsi(a: f32) callconv(.C) i32 { return fixint(f32, i32, a); } +pub fn __aeabi_f2iz(a: f32) callconv(.AAPCS) i32 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __fixsfsi, .{a}); +} + test "import fixsfsi" { _ = @import("fixsfsi_test.zig"); } diff --git a/lib/std/special/compiler_rt/fixunsdfdi.zig b/lib/std/special/compiler_rt/fixunsdfdi.zig index 9d41d4b740..800c9b1148 100644 --- a/lib/std/special/compiler_rt/fixunsdfdi.zig +++ b/lib/std/special/compiler_rt/fixunsdfdi.zig @@ -6,6 +6,11 @@ pub fn __fixunsdfdi(a: f64) callconv(.C) u64 { return fixuint(f64, u64, a); } +pub fn __aeabi_d2ulz(a: f64) callconv(.AAPCS) u64 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __fixunsdfdi, .{a}); +} + test "import fixunsdfdi" { _ = @import("fixunsdfdi_test.zig"); } diff --git a/lib/std/special/compiler_rt/fixunsdfsi.zig b/lib/std/special/compiler_rt/fixunsdfsi.zig index 044523512c..156c21a887 100644 --- a/lib/std/special/compiler_rt/fixunsdfsi.zig +++ b/lib/std/special/compiler_rt/fixunsdfsi.zig @@ -6,6 +6,11 @@ pub fn __fixunsdfsi(a: f64) callconv(.C) u32 { return fixuint(f64, u32, a); } +pub fn __aeabi_d2uiz(arg: f64) callconv(.AAPCS) u32 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __fixunsdfsi, .{arg}); +} + test "import fixunsdfsi" { _ = @import("fixunsdfsi_test.zig"); } diff --git a/lib/std/special/compiler_rt/fixunssfdi.zig b/lib/std/special/compiler_rt/fixunssfdi.zig index a42121aeec..ec00a7ee35 100644 --- a/lib/std/special/compiler_rt/fixunssfdi.zig +++ b/lib/std/special/compiler_rt/fixunssfdi.zig @@ -6,6 +6,11 @@ pub fn __fixunssfdi(a: f32) callconv(.C) u64 { return fixuint(f32, u64, a); } +pub fn __aeabi_f2ulz(a: f32) callconv(.AAPCS) u64 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __fixunssfdi, .{a}); +} + test "import fixunssfdi" { _ = @import("fixunssfdi_test.zig"); } diff --git a/lib/std/special/compiler_rt/fixunssfsi.zig b/lib/std/special/compiler_rt/fixunssfsi.zig index 00f7c8ad22..a4e5a323f5 100644 --- a/lib/std/special/compiler_rt/fixunssfsi.zig +++ b/lib/std/special/compiler_rt/fixunssfsi.zig @@ -6,6 +6,11 @@ pub fn __fixunssfsi(a: f32) callconv(.C) u32 { return fixuint(f32, u32, a); } +pub fn __aeabi_f2uiz(a: f32) callconv(.AAPCS) u32 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __fixunssfsi, .{a}); +} + test "import fixunssfsi" { _ = @import("fixunssfsi_test.zig"); } diff --git a/lib/std/special/compiler_rt/floatdidf.zig b/lib/std/special/compiler_rt/floatdidf.zig index 93bd0c8a3e..afe9e906fd 100644 --- a/lib/std/special/compiler_rt/floatdidf.zig +++ b/lib/std/special/compiler_rt/floatdidf.zig @@ -17,6 +17,11 @@ pub fn __floatdidf(a: i64) callconv(.C) f64 { return (high - twop52) + @bitCast(f64, low); } +pub fn __aeabi_l2d(arg: i64) callconv(.AAPCS) f64 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __floatdidf, .{arg}); +} + test "import floatdidf" { _ = @import("floatdidf_test.zig"); } diff --git a/lib/std/special/compiler_rt/floatsiXf.zig b/lib/std/special/compiler_rt/floatsiXf.zig index 30a09de90c..ef3aba34d4 100644 --- a/lib/std/special/compiler_rt/floatsiXf.zig +++ b/lib/std/special/compiler_rt/floatsiXf.zig @@ -68,6 +68,16 @@ pub fn __floatsitf(arg: i32) callconv(.C) f128 { return @call(.{ .modifier = .always_inline }, floatsiXf, .{ f128, arg }); } +pub fn __aeabi_i2d(arg: i32) callconv(.AAPCS) f64 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __floatsidf, .{arg}); +} + +pub fn __aeabi_i2f(arg: i32) callconv(.AAPCS) f32 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __floatsisf, .{arg}); +} + fn test_one_floatsitf(a: i32, expected: u128) void { const r = __floatsitf(a); std.testing.expect(@bitCast(u128, r) == expected); diff --git a/lib/std/special/compiler_rt/floatundidf.zig b/lib/std/special/compiler_rt/floatundidf.zig index c8803b4c6c..1efe55da40 100644 --- a/lib/std/special/compiler_rt/floatundidf.zig +++ b/lib/std/special/compiler_rt/floatundidf.zig @@ -19,6 +19,11 @@ pub fn __floatundidf(a: u64) callconv(.C) f64 { return (@bitCast(f64, high) - twop84_plus_twop52) + @bitCast(f64, low); } +pub fn __aeabi_ul2d(arg: u64) callconv(.AAPCS) f64 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __floatundidf, .{arg}); +} + test "import floatundidf" { _ = @import("floatundidf_test.zig"); } diff --git a/lib/std/special/compiler_rt/floatundisf.zig b/lib/std/special/compiler_rt/floatundisf.zig index b311438fa2..41ff02daee 100644 --- a/lib/std/special/compiler_rt/floatundisf.zig +++ b/lib/std/special/compiler_rt/floatundisf.zig @@ -4,7 +4,7 @@ const maxInt = std.math.maxInt; const FLT_MANT_DIG = 24; -pub extern fn __floatundisf(arg: u64) f32 { +pub fn __floatundisf(arg: u64) callconv(.C) f32 { @setRuntimeSafety(builtin.is_test); if (arg == 0) return 0; @@ -56,6 +56,11 @@ pub extern fn __floatundisf(arg: u64) f32 { return @bitCast(f32, result); } +pub fn __aeabi_ul2f(arg: u64) callconv(.AAPCS) f32 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __floatundisf, .{arg}); +} + fn test__floatundisf(a: u64, expected: f32) void { std.testing.expectEqual(expected, __floatundisf(a)); } diff --git a/lib/std/special/compiler_rt/floatunsidf.zig b/lib/std/special/compiler_rt/floatunsidf.zig index 92a7870806..771b4938e1 100644 --- a/lib/std/special/compiler_rt/floatunsidf.zig +++ b/lib/std/special/compiler_rt/floatunsidf.zig @@ -18,6 +18,11 @@ pub fn __floatunsidf(arg: u32) callconv(.C) f64 { return @bitCast(f64, mant | (exp + 1023) << 52); } +pub fn __aeabi_ui2d(arg: u32) callconv(.AAPCS) f64 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __floatunsidf, .{arg}); +} + fn test_one_floatunsidf(a: u32, expected: u64) void { const r = __floatunsidf(a); std.testing.expect(@bitCast(u64, r) == expected); diff --git a/lib/std/special/compiler_rt/floatunsisf.zig b/lib/std/special/compiler_rt/floatunsisf.zig index 777252c575..c11243e6e4 100644 --- a/lib/std/special/compiler_rt/floatunsisf.zig +++ b/lib/std/special/compiler_rt/floatunsisf.zig @@ -6,7 +6,7 @@ const significandBits = 23; const exponentBias = 127; const implicitBit = @as(u32, 1) << significandBits; -pub extern fn __floatunsisf(arg: u32) f32 { +pub fn __floatunsisf(arg: u32) callconv(.C) f32 { @setRuntimeSafety(builtin.is_test); if (arg == 0) return 0.0; @@ -38,6 +38,11 @@ pub extern fn __floatunsisf(arg: u32) f32 { return @bitCast(f32, result); } +pub fn __aeabi_ui2f(arg: u32) callconv(.AAPCS) f32 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __floatunsisf, .{arg}); +} + fn test_one_floatunsisf(a: u32, expected: u32) void { const r = __floatunsisf(a); std.testing.expect(@bitCast(u32, r) == expected); diff --git a/lib/std/special/compiler_rt/mulXf3.zig b/lib/std/special/compiler_rt/mulXf3.zig index 9457bfb86e..103692f610 100644 --- a/lib/std/special/compiler_rt/mulXf3.zig +++ b/lib/std/special/compiler_rt/mulXf3.zig @@ -16,6 +16,16 @@ pub fn __mulsf3(a: f32, b: f32) callconv(.C) f32 { return mulXf3(f32, a, b); } +pub fn __aeabi_fmul(a: f32, b: f32) callconv(.C) f32 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __mulsf3, .{ a, b }); +} + +pub fn __aeabi_dmul(a: f64, b: f64) callconv(.C) f64 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __muldf3, .{ a, b }); +} + fn mulXf3(comptime T: type, a: T, b: T) T { @setRuntimeSafety(builtin.is_test); const Z = @IntType(false, T.bit_count); diff --git a/lib/std/special/compiler_rt/negXf2.zig b/lib/std/special/compiler_rt/negXf2.zig index e21e36b955..c41b1b48d7 100644 --- a/lib/std/special/compiler_rt/negXf2.zig +++ b/lib/std/special/compiler_rt/negXf2.zig @@ -8,6 +8,16 @@ pub fn __negdf2(a: f64) callconv(.C) f64 { return negXf2(f64, a); } +pub fn __aeabi_fneg(arg: f32) callconv(.AAPCS) f32 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __negsf2, .{arg}); +} + +pub fn __aeabi_dneg(arg: f64) callconv(.AAPCS) f64 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __negdf2, .{arg}); +} + fn negXf2(comptime T: type, a: T) T { const Z = @IntType(false, T.bit_count); diff --git a/lib/std/special/compiler_rt/truncXfYf2.zig b/lib/std/special/compiler_rt/truncXfYf2.zig index 10b097e777..0a09dea84c 100644 --- a/lib/std/special/compiler_rt/truncXfYf2.zig +++ b/lib/std/special/compiler_rt/truncXfYf2.zig @@ -20,6 +20,21 @@ pub fn __truncdfsf2(a: f64) callconv(.C) f32 { return truncXfYf2(f32, f64, a); } +pub fn __aeabi_d2f(a: f64) callconv(.AAPCS) f32 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __truncdfsf2, .{a}); +} + +pub fn __aeabi_d2h(a: f64) callconv(.AAPCS) u16 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __truncdfhf2, .{a}); +} + +pub fn __aeabi_f2h(a: f32) callconv(.AAPCS) u16 { + @setRuntimeSafety(false); + return @call(.{ .modifier = .always_inline }, __truncsfhf2, .{a}); +} + inline fn truncXfYf2(comptime dst_t: type, comptime src_t: type, a: src_t) dst_t { const src_rep_t = @IntType(false, @typeInfo(src_t).Float.bits); const dst_rep_t = @IntType(false, @typeInfo(dst_t).Float.bits); |
