diff options
| author | Chris Lattner <sabre@nondot.org> | 2006-12-11 01:17:00 +0000 | 
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2006-12-11 01:17:00 +0000 | 
| commit | e810140c4b2785eaa49b2e6c2e7f65635a32475d (patch) | |
| tree | 89fa7f5482b240eb169675500c54db5845ed2657 /llvm/lib | |
| parent | e9c430c5d89fb67b0f4e34a3dced6ddded428298 (diff) | |
| download | bcm5719-llvm-e810140c4b2785eaa49b2e6c2e7f65635a32475d.tar.gz bcm5719-llvm-e810140c4b2785eaa49b2e6c2e7f65635a32475d.zip | |
trunc to integer, not to FP.
llvm-svn: 32426
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/Transforms/Scalar/ScalarReplAggregates.cpp | 13 | 
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); | 

