a71bfc249d
This removes the compiler_rt.setXmm0 hack. Instead, for the functions that use i128 or u128 in their parameter and return types, we use `@Vector(2, u64)` which generates the LLVM IR `<2 x i64>` type that matches what Clang generates for `typedef int ti_int __attribute__ ((mode (TI)))` when targeting Windows x86_64.
19 lines
612 B
Zig
19 lines
612 B
Zig
const udivmod = @import("udivmod.zig").udivmod;
|
|
const builtin = @import("builtin");
|
|
const compiler_rt = @import("../compiler_rt.zig");
|
|
|
|
pub extern fn __udivmodti4(a: u128, b: u128, maybe_rem: ?*u128) u128 {
|
|
@setRuntimeSafety(builtin.is_test);
|
|
return udivmod(u128, a, b, maybe_rem);
|
|
}
|
|
|
|
const v128 = @Vector(2, u64);
|
|
pub extern fn __udivmodti4_windows_x86_64(a: v128, b: v128, maybe_rem: ?*u128) v128 {
|
|
@setRuntimeSafety(builtin.is_test);
|
|
return @bitCast(v128, udivmod(u128, @bitCast(u128, a), @bitCast(u128, b), maybe_rem));
|
|
}
|
|
|
|
test "import udivmodti4" {
|
|
_ = @import("udivmodti4_test.zig");
|
|
}
|