From 509f85140ca777a028b87ccdb46bb19b8f052f8b Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Mon, 11 Dec 2006 01:17:00 +0000 Subject: [PATCH] trunc to integer, not to FP. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@32426 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Transforms/Scalar/ScalarReplAggregates.cpp | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/lib/Transforms/Scalar/ScalarReplAggregates.cpp b/lib/Transforms/Scalar/ScalarReplAggregates.cpp index 4bdf6523a30..764cda69e36 100644 --- a/lib/Transforms/Scalar/ScalarReplAggregates.cpp +++ b/lib/Transforms/Scalar/ScalarReplAggregates.cpp @@ -660,8 +660,17 @@ void SROA::ConvertUsesToScalar(Value *Ptr, AllocaInst *NewAI, unsigned Offset) { } else if (LI->getType()->isFloatingPoint()) { // If needed, truncate the integer to the appropriate size. if (NV->getType()->getPrimitiveSize() > - LI->getType()->getPrimitiveSize()) - NV = new TruncInst(NV, LI->getType(), LI->getName(), LI); + LI->getType()->getPrimitiveSize()) { + switch (LI->getType()->getTypeID()) { + default: assert(0 && "Unknown FP type!"); + case Type::FloatTyID: + NV = new TruncInst(NV, Type::UIntTy, LI->getName(), LI); + break; + case Type::DoubleTyID: + NV = new TruncInst(NV, Type::ULongTy, LI->getName(), LI); + break; + } + } // Then do a bitcast. NV = new BitCastInst(NV, LI->getType(), LI->getName(), LI);