Implement codegen for builtin infinity functions.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@44604 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/CodeGen/CGBuiltin.cpp b/CodeGen/CGBuiltin.cpp
index 27c82e8..8f9b7b3 100644
--- a/CodeGen/CGBuiltin.cpp
+++ b/CodeGen/CGBuiltin.cpp
@@ -112,6 +112,22 @@
return RValue::get(V);
}
+ case Builtin::BI__builtin_inff: {
+ llvm::APFloat f(llvm::APFloat::IEEEsingle,
+ llvm::APFloat::fcInfinity, false);
+
+ llvm::Value *V = llvm::ConstantFP::get(llvm::Type::FloatTy, f);
+ return RValue::get(V);
+ }
+ case Builtin::BI__builtin_inf:
+ // FIXME: mapping long double onto double.
+ case Builtin::BI__builtin_infl: {
+ llvm::APFloat f(llvm::APFloat::IEEEdouble,
+ llvm::APFloat::fcInfinity, false);
+
+ llvm::Value *V = llvm::ConstantFP::get(llvm::Type::DoubleTy, f);
+ return RValue::get(V);
+ }
}
return RValue::get(0);
diff --git a/include/clang/AST/Builtins.def b/include/clang/AST/Builtins.def
index d95dbd4..c0e978f 100644
--- a/include/clang/AST/Builtins.def
+++ b/include/clang/AST/Builtins.def
@@ -54,9 +54,9 @@
// F -> this is a libc/libm function with a '__builtin_' prefix added.
// Standard libc/libm functions:
-BUILTIN(__builtin_inf , "d" , "ncF")
-BUILTIN(__builtin_inff , "f" , "ncF")
-BUILTIN(__builtin_infl , "Ld" , "ncF")
+BUILTIN(__builtin_inf , "d" , "nc")
+BUILTIN(__builtin_inff , "f" , "nc")
+BUILTIN(__builtin_infl , "Ld" , "nc")
BUILTIN(__builtin_abs , "ii" , "ncF")
BUILTIN(__builtin_fabs , "dd" , "ncF")
BUILTIN(__builtin_fabsf, "ff" , "ncF")