summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2006-12-11 01:17:00 +0000
committerChris Lattner <sabre@nondot.org>2006-12-11 01:17:00 +0000
commite810140c4b2785eaa49b2e6c2e7f65635a32475d (patch)
tree89fa7f5482b240eb169675500c54db5845ed2657
parente9c430c5d89fb67b0f4e34a3dced6ddded428298 (diff)
downloadbcm5719-llvm-e810140c4b2785eaa49b2e6c2e7f65635a32475d.tar.gz
bcm5719-llvm-e810140c4b2785eaa49b2e6c2e7f65635a32475d.zip
trunc to integer, not to FP.
llvm-svn: 32426
-rw-r--r--llvm/lib/Transforms/Scalar/ScalarReplAggregates.cpp13
1 files changed, 11 insertions, 2 deletions
diff --git a/llvm/lib/Transforms/Scalar/ScalarReplAggregates.cpp b/llvm/lib/Transforms/Scalar/ScalarReplAggregates.cpp
index 4bdf6523a30..764cda69e36 100644
--- a/llvm/lib/Transforms/Scalar/ScalarReplAggregates.cpp
+++ b/llvm/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);
OpenPOWER on IntegriCloud