]> granicus.if.org Git - clang/commitdiff
Lower __builtin_fabs* to @llvm.fabs.*
authorReid Kleckner <reid@kleckner.net>
Mon, 3 Nov 2014 23:52:09 +0000 (23:52 +0000)
committerReid Kleckner <reid@kleckner.net>
Mon, 3 Nov 2014 23:52:09 +0000 (23:52 +0000)
mingw64's headers implement fabs by calling __builtin_fabs, so using the
library call results in an infinite loop. If the backend legalizes
@llvm.fabs as a call to fabs later, things should work out, as the crt
provides a definition.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@221206 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CGBuiltin.cpp
test/CodeGen/builtins.c

index 0972e28069d9fcb822ba71ed16b7f92fa52d42c8..aa11a906f406c1daab9d36e3fc7da0b663e30773 100644 (file)
@@ -245,6 +245,13 @@ RValue CodeGenFunction::EmitBuiltinExpr(const FunctionDecl *FD,
 
     return RValue::get(Result);
   }
+  case Builtin::BI__builtin_fabs:
+  case Builtin::BI__builtin_fabsf:
+  case Builtin::BI__builtin_fabsl: {
+    Value *Arg1 = EmitScalarExpr(E->getArg(0));
+    Value *Result = EmitFAbs(*this, Arg1);
+    return RValue::get(Result);
+  }
   case Builtin::BI__builtin_fmod:
   case Builtin::BI__builtin_fmodf:
   case Builtin::BI__builtin_fmodl: {
index 6dd749a90bdfa5badf252ee5c3957b949e28794c..1ab29a659b31a8de05425f4d3cca43d817f841f2 100644 (file)
@@ -211,6 +211,13 @@ void test_float_builtin_ops(float F, double D, long double LD) {
 
   resld = __builtin_fmodl(LD,LD);
   // CHECK: frem x86_fp80
+
+  resf = __builtin_fabsf(F);
+  resd = __builtin_fabs(D);
+  resld = __builtin_fabsl(LD);
+  // CHECK: call float @llvm.fabs.f32(float
+  // CHECK: call double @llvm.fabs.f64(double
+  // CHECK: call x86_fp80 @llvm.fabs.f80(x86_fp80
 }
 
 // CHECK-LABEL: define void @test_builtin_longjmp