diff options
author | Benjamin Kramer <benny.kra@googlemail.com> | 2012-02-16 15:19:59 +0000 |
---|---|---|
committer | Benjamin Kramer <benny.kra@googlemail.com> | 2012-02-16 15:19:59 +0000 |
commit | ea79b8e03ca7c7be72832c11e9d4d78f11b728b3 (patch) | |
tree | a50618e2d2d8ddf87cf1b3504b97fe27160ff9c7 | |
parent | 475ebf5a74c0c5d0faf37b943ac871ad0f5d5677 (diff) | |
download | external_llvm-ea79b8e03ca7c7be72832c11e9d4d78f11b728b3.zip external_llvm-ea79b8e03ca7c7be72832c11e9d4d78f11b728b3.tar.gz external_llvm-ea79b8e03ca7c7be72832c11e9d4d78f11b728b3.tar.bz2 |
Revert "InstSimplify: Strip pointer casts early."
Turns out this isn't safe, because the code below depends on LHS and RHS having
the same type.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@150695 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Analysis/InstructionSimplify.cpp | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/lib/Analysis/InstructionSimplify.cpp b/lib/Analysis/InstructionSimplify.cpp index c9ab52c..9d5b74c 100644 --- a/lib/Analysis/InstructionSimplify.cpp +++ b/lib/Analysis/InstructionSimplify.cpp @@ -1542,10 +1542,6 @@ static Value *SimplifyICmpInst(unsigned Predicate, Value *LHS, Value *RHS, Type *ITy = GetCompareTy(LHS); // The return type. Type *OpTy = LHS->getType(); // The operand type. - // Remove pointer casts that don't change the value. - LHS = LHS->stripPointerCasts(); - RHS = RHS->stripPointerCasts(); - // icmp X, X -> true/false // X icmp undef -> true/false. For example, icmp ugt %X, undef -> false // because X could be 0. @@ -1595,8 +1591,11 @@ static Value *SimplifyICmpInst(unsigned Predicate, Value *LHS, Value *RHS, // to the case where LHS is a global variable address or null is pointless, // since if both LHS and RHS are constants then we already constant folded // the compare, and if only one of them is then we moved it to RHS already. - if (isa<AllocaInst>(LHS) && (isa<GlobalValue>(RHS) || isa<AllocaInst>(RHS) || - isa<ConstantPointerNull>(RHS))) + Value *LHSPtr = LHS->stripPointerCasts(); + Value *RHSPtr = RHS->stripPointerCasts(); + if (isa<AllocaInst>(LHSPtr) && (isa<GlobalValue>(RHSPtr) || + isa<AllocaInst>(RHSPtr) || + isa<ConstantPointerNull>(RHSPtr))) // We already know that LHS != RHS. return ConstantInt::get(ITy, CmpInst::isFalseWhenEqual(Pred)); |