[llvm] r277691 - Reinstate "[CloneFunction] Don't remove side effecting calls"

Hans Wennborg via llvm-commits llvm-commits at lists.llvm.org
Thu Aug 4 15:52:39 PDT 2016


Thanks! I grabbed r277773 as well just to be sure :-) Merged in r277781.

Since this is close to ToT, please let me know if any problems come up
that require follow-ups.

Cheers,
Hans

On Thu, Aug 4, 2016 at 10:59 AM, David Majnemer
<david.majnemer at gmail.com> wrote:
> Yes along with r277693.
>
> On Thu, Aug 4, 2016 at 10:13 AM, Hans Wennborg <hans at chromium.org> wrote:
>>
>> Should we merge this to 3.9?
>>
>> On Wed, Aug 3, 2016 at 9:24 PM, David Majnemer via llvm-commits
>> <llvm-commits at lists.llvm.org> wrote:
>> > Author: majnemer
>> > Date: Wed Aug  3 23:24:02 2016
>> > New Revision: 277691
>> >
>> > URL: http://llvm.org/viewvc/llvm-project?rev=277691&view=rev
>> > Log:
>> > Reinstate "[CloneFunction] Don't remove side effecting calls"
>> >
>> > This reinstates r277611 + r277614 and reverts r277642.  A cast_or_null
>> > should have been a dyn_cast_or_null.
>> >
>> > Modified:
>> >     llvm/trunk/lib/Analysis/InstructionSimplify.cpp
>> >     llvm/trunk/lib/Transforms/Utils/CloneFunction.cpp
>> >     llvm/trunk/test/Transforms/Inline/inline_constprop.ll
>> >
>> > Modified: llvm/trunk/lib/Analysis/InstructionSimplify.cpp
>> > URL:
>> > http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Analysis/InstructionSimplify.cpp?rev=277691&r1=277690&r2=277691&view=diff
>> >
>> > ==============================================================================
>> > --- llvm/trunk/lib/Analysis/InstructionSimplify.cpp (original)
>> > +++ llvm/trunk/lib/Analysis/InstructionSimplify.cpp Wed Aug  3 23:24:02
>> > 2016
>> > @@ -4356,7 +4356,8 @@ static bool replaceAndRecursivelySimplif
>> >
>> >      // Gracefully handle edge cases where the instruction is not wired
>> > into any
>> >      // parent block.
>> > -    if (I->getParent())
>> > +    if (I->getParent() && !I->isEHPad() && !isa<TerminatorInst>(I) &&
>> > +        !I->mayHaveSideEffects())
>> >        I->eraseFromParent();
>> >    } else {
>> >      Worklist.insert(I);
>> > @@ -4384,7 +4385,8 @@ static bool replaceAndRecursivelySimplif
>> >
>> >      // Gracefully handle edge cases where the instruction is not wired
>> > into any
>> >      // parent block.
>> > -    if (I->getParent())
>> > +    if (I->getParent() && !I->isEHPad() && !isa<TerminatorInst>(I) &&
>> > +        !I->mayHaveSideEffects())
>> >        I->eraseFromParent();
>> >    }
>> >    return Simplified;
>> >
>> > Modified: llvm/trunk/lib/Transforms/Utils/CloneFunction.cpp
>> > URL:
>> > http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Utils/CloneFunction.cpp?rev=277691&r1=277690&r2=277691&view=diff
>> >
>> > ==============================================================================
>> > --- llvm/trunk/lib/Transforms/Utils/CloneFunction.cpp (original)
>> > +++ llvm/trunk/lib/Transforms/Utils/CloneFunction.cpp Wed Aug  3
>> > 23:24:02 2016
>> > @@ -14,6 +14,7 @@
>> >
>> > //===----------------------------------------------------------------------===//
>> >
>> >  #include "llvm/Transforms/Utils/Cloning.h"
>> > +#include "llvm/ADT/SetVector.h"
>> >  #include "llvm/ADT/SmallVector.h"
>> >  #include "llvm/Analysis/ConstantFolding.h"
>> >  #include "llvm/Analysis/InstructionSimplify.h"
>> > @@ -552,9 +553,39 @@ void llvm::CloneAndPruneIntoFromInst(Fun
>> >    // two PHINodes, the iteration over the old PHIs remains valid, and
>> > the
>> >    // mapping will just map us to the new node (which may not even be a
>> > PHI
>> >    // node).
>> > +  const DataLayout &DL = NewFunc->getParent()->getDataLayout();
>> > +  SmallSetVector<const Value *, 8> Worklist;
>> >    for (unsigned Idx = 0, Size = PHIToResolve.size(); Idx != Size;
>> > ++Idx)
>> > -    if (PHINode *PN = dyn_cast<PHINode>(VMap[PHIToResolve[Idx]]))
>> > -      recursivelySimplifyInstruction(PN);
>> > +    if (isa<PHINode>(VMap[PHIToResolve[Idx]]))
>> > +      Worklist.insert(PHIToResolve[Idx]);
>> > +
>> > +  // Note that we must test the size on each iteration, the worklist
>> > can grow.
>> > +  for (unsigned Idx = 0; Idx != Worklist.size(); ++Idx) {
>> > +    const Value *OrigV = Worklist[Idx];
>> > +    auto *I = cast_or_null<Instruction>(VMap.lookup(OrigV));
>> > +    if (!I)
>> > +      continue;
>> > +
>> > +    // See if this instruction simplifies.
>> > +    Value *SimpleV = SimplifyInstruction(I, DL);
>> > +    if (!SimpleV)
>> > +      continue;
>> > +
>> > +    // Stash away all the uses of the old instruction so we can check
>> > them for
>> > +    // recursive simplifications after a RAUW. This is cheaper than
>> > checking all
>> > +    // uses of To on the recursive step in most cases.
>> > +    for (const User *U : OrigV->users())
>> > +      Worklist.insert(cast<Instruction>(U));
>> > +
>> > +    // Replace the instruction with its simplified value.
>> > +    I->replaceAllUsesWith(SimpleV);
>> > +
>> > +    // If the original instruction had no side effects, remove it.
>> > +    if (isInstructionTriviallyDead(I))
>> > +      I->eraseFromParent();
>> > +    else
>> > +      VMap[OrigV] = I;
>> > +  }
>> >
>> >    // Now that the inlined function body has been fully constructed, go
>> > through
>> >    // and zap unconditional fall-through branches. This happens all the
>> > time when
>> >
>> > Modified: llvm/trunk/test/Transforms/Inline/inline_constprop.ll
>> > URL:
>> > http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/Inline/inline_constprop.ll?rev=277691&r1=277690&r2=277691&view=diff
>> >
>> > ==============================================================================
>> > --- llvm/trunk/test/Transforms/Inline/inline_constprop.ll (original)
>> > +++ llvm/trunk/test/Transforms/Inline/inline_constprop.ll Wed Aug  3
>> > 23:24:02 2016
>> > @@ -279,3 +279,25 @@ return:
>> >    %retval.0 = phi i32* [ %b, %if.end3 ], [ %a, %if.then ]
>> >    ret i32* %retval.0
>> >  }
>> > +
>> > +declare i32 @PR28802.external(i32 returned %p1)
>> > +
>> > +define internal i32 @PR28802.callee() {
>> > +entry:
>> > +  br label %cont
>> > +
>> > +cont:
>> > +  %0 = phi i32 [ 0, %entry ]
>> > +  %call = call i32 @PR28802.external(i32 %0)
>> > +  ret i32 %call
>> > +}
>> > +
>> > +define i32 @PR28802() {
>> > +entry:
>> > +  %call = call i32 @PR28802.callee()
>> > +  ret i32 %call
>> > +}
>> > +
>> > +; CHECK-LABEL: define i32 @PR28802(
>> > +; CHECK: call i32 @PR28802.external(i32 0)
>> > +; CHECK: ret i32 0
>> >
>> >
>> > _______________________________________________
>> > llvm-commits mailing list
>> > llvm-commits at lists.llvm.org
>> > http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits
>
>


More information about the llvm-commits mailing list