aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen/CodeGenTypes.cpp
diff options
context:
space:
mode:
authorEli Friedman <eli.friedman@gmail.com>2008-05-27 04:20:05 +0000
committerEli Friedman <eli.friedman@gmail.com>2008-05-27 04:20:05 +0000
commitf6a943e047f541619a2202f9e43b20b3d7c0a96d (patch)
tree6ef27cf552eac2a32760d3e8e969f4248da7eb5d /lib/CodeGen/CodeGenTypes.cpp
parent3c0eb160ca1361a82b9f15b3b40a2425adc14d0f (diff)
Generalize the float type generation code, and specifically fix the
codegen of X86 long double. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@51578 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/CodeGenTypes.cpp')
-rw-r--r--lib/CodeGen/CodeGenTypes.cpp24
1 files changed, 19 insertions, 5 deletions
diff --git a/lib/CodeGen/CodeGenTypes.cpp b/lib/CodeGen/CodeGenTypes.cpp
index b640c912e5..aa0d2ed053 100644
--- a/lib/CodeGen/CodeGenTypes.cpp
+++ b/lib/CodeGen/CodeGenTypes.cpp
@@ -161,6 +161,21 @@ void CodeGenTypes::CollectObjCIvarTypes(ObjCInterfaceDecl *ObjCClass,
}
}
+static const llvm::Type* getTypeForFormat(const llvm::fltSemantics * format) {
+ if (format == &llvm::APFloat::IEEEsingle)
+ return llvm::Type::FloatTy;
+ if (format == &llvm::APFloat::IEEEdouble)
+ return llvm::Type::DoubleTy;
+ if (format == &llvm::APFloat::IEEEquad)
+ return llvm::Type::FP128Ty;
+ if (format == &llvm::APFloat::PPCDoubleDouble)
+ return llvm::Type::PPC_FP128Ty;
+ if (format == &llvm::APFloat::x87DoubleExtended)
+ return llvm::Type::X86_FP80Ty;
+ assert(9 && "Unknown float format!");
+ return 0;
+}
+
const llvm::Type *CodeGenTypes::ConvertNewType(QualType T) {
const clang::Type &Ty = *T.getCanonicalType();
@@ -195,13 +210,12 @@ const llvm::Type *CodeGenTypes::ConvertNewType(QualType T) {
return llvm::IntegerType::get(
static_cast<unsigned>(Context.getTypeSize(T)));
- case BuiltinType::Float: return llvm::Type::FloatTy;
+ case BuiltinType::Float:
+ return getTypeForFormat(Context.Target.getFloatFormat());
case BuiltinType::Double:
- return (Context.Target.getDoubleFormat() == &llvm::APFloat::IEEEdouble) ?
- llvm::Type::DoubleTy : llvm::Type::FloatTy;
+ return getTypeForFormat(Context.Target.getDoubleFormat());
case BuiltinType::LongDouble:
- // FIXME: mapping long double onto double.
- return llvm::Type::DoubleTy;
+ return getTypeForFormat(Context.Target.getLongDoubleFormat());
}
break;
}