mirror of
https://github.com/RPCS3/llvm.git
synced 2025-02-14 15:57:47 +00:00
[InstCombine] Don't try to sink EH pad instructions
Found by inspection, this change should not effect the existing landingpad behavior. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@244391 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
5ba219fe8d
commit
3309afe8f5
@ -2672,7 +2672,7 @@ static bool TryToSinkInstruction(Instruction *I, BasicBlock *DestBlock) {
|
||||
assert(I->hasOneUse() && "Invariants didn't hold!");
|
||||
|
||||
// Cannot move control-flow-involving, volatile loads, vaarg, etc.
|
||||
if (isa<PHINode>(I) || isa<LandingPadInst>(I) || I->mayHaveSideEffects() ||
|
||||
if (isa<PHINode>(I) || I->isEHPad() || I->mayHaveSideEffects() ||
|
||||
isa<TerminatorInst>(I))
|
||||
return false;
|
||||
|
||||
@ -2975,7 +2975,7 @@ static bool prepareICWorklistFromFunction(Function &F, const DataLayout &DL,
|
||||
Instruction *Inst = --I;
|
||||
if (!Inst->use_empty())
|
||||
Inst->replaceAllUsesWith(UndefValue::get(Inst->getType()));
|
||||
if (isa<LandingPadInst>(Inst)) {
|
||||
if (Inst->isEHPad()) {
|
||||
EndInst = Inst;
|
||||
continue;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user