Changes in directory llvm/lib/Transforms/Scalar:
InstructionCombining.cpp updated: 1.415 -> 1.416 --- Log message: Implement casts.ll:test26: a cast from float -> double -> integer, doesn't need the float->double part. --- Diffs of the changes: (+11 -2) InstructionCombining.cpp | 13 +++++++++++-- 1 files changed, 11 insertions(+), 2 deletions(-) Index: llvm/lib/Transforms/Scalar/InstructionCombining.cpp diff -u llvm/lib/Transforms/Scalar/InstructionCombining.cpp:1.415 llvm/lib/Transforms/Scalar/InstructionCombining.cpp:1.416 --- llvm/lib/Transforms/Scalar/InstructionCombining.cpp:1.415 Mon Jan 16 13:47:21 2006 +++ llvm/lib/Transforms/Scalar/InstructionCombining.cpp Thu Jan 19 01:40:22 2006 @@ -3799,8 +3799,8 @@ // isEliminableCastOfCast - Return true if it is valid to eliminate the CI // instruction. // -static inline bool isEliminableCastOfCast(const Type *SrcTy, const Type *MidTy, - const Type *DstTy, TargetData *TD) { +static bool isEliminableCastOfCast(const Type *SrcTy, const Type *MidTy, + const Type *DstTy, TargetData *TD) { // It is legal to eliminate the instruction if casting A->B->A if the sizes // are identical and the bits don't get reinterpreted (for example @@ -3856,6 +3856,15 @@ return ResultCast == FirstCast; } } + + // If this is a cast from 'float -> double -> integer', cast from + // 'float -> integer' directly, as the value isn't changed by the + // float->double conversion. + if (SrcTy->isFloatingPoint() && MidTy->isFloatingPoint() && + DstTy->isIntegral() && + SrcTy->getPrimitiveSize() < MidTy->getPrimitiveSize()) + return true; + return false; } _______________________________________________ llvm-commits mailing list llvm-commits@cs.uiuc.edu http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits