aboutsummaryrefslogtreecommitdiff
path: root/src/codegen/llvm.zig
diff options
context:
space:
mode:
Diffstat (limited to 'src/codegen/llvm.zig')
-rw-r--r--src/codegen/llvm.zig11
1 files changed, 5 insertions, 6 deletions
diff --git a/src/codegen/llvm.zig b/src/codegen/llvm.zig
index aa0a99ea6c..80f2d8b653 100644
--- a/src/codegen/llvm.zig
+++ b/src/codegen/llvm.zig
@@ -2874,13 +2874,8 @@ pub const FuncGen = struct {
const inst_ty = self.air.typeOfIndex(inst);
if (inst_ty.isRuntimeFloat()) {
- const result_llvm_ty = try self.dg.llvmType(inst_ty);
- const zero = result_llvm_ty.constNull();
const result = self.builder.buildFDiv(lhs, rhs, "");
- const ceiled = try self.callCeil(result, inst_ty);
- const floored = try self.callFloor(result, inst_ty);
- const ltz = self.builder.buildFCmp(.OLT, lhs, zero, "");
- return self.builder.buildSelect(ltz, ceiled, floored, "");
+ return self.callTrunc(result, inst_ty);
}
if (inst_ty.isSignedInt()) return self.builder.buildSDiv(lhs, rhs, "");
return self.builder.buildUDiv(lhs, rhs, "");
@@ -3641,6 +3636,10 @@ pub const FuncGen = struct {
return self.callFloatUnary(arg, ty, "ceil");
}
+ fn callTrunc(self: *FuncGen, arg: *const llvm.Value, ty: Type) !*const llvm.Value {
+ return self.callFloatUnary(arg, ty, "trunc");
+ }
+
fn callFloatUnary(self: *FuncGen, arg: *const llvm.Value, ty: Type, name: []const u8) !*const llvm.Value {
const target = self.dg.module.getTarget();