mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-05 12:31:33 +00:00
Fix Transforms/InstCombine/2007-02-01-LoadSinkAlloca.ll, a serious code
pessimization where instcombine can sink a load (good for code size) that prevents an alloca from being promoted by mem2reg (bad for everything). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@33771 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
5c70a012c7
commit
fd905caa77
@ -7464,12 +7464,36 @@ Instruction *InstCombiner::FoldPHIArgBinOpIntoPHI(PHINode &PN) {
|
|||||||
/// of the block that defines it. This means that it must be obvious the value
|
/// of the block that defines it. This means that it must be obvious the value
|
||||||
/// of the load is not changed from the point of the load to the end of the
|
/// of the load is not changed from the point of the load to the end of the
|
||||||
/// block it is in.
|
/// block it is in.
|
||||||
|
///
|
||||||
|
/// Finally, it is safe, but not profitable, to sink a load targetting a
|
||||||
|
/// non-address-taken alloca. Doing so will cause us to not promote the alloca
|
||||||
|
/// to a register.
|
||||||
static bool isSafeToSinkLoad(LoadInst *L) {
|
static bool isSafeToSinkLoad(LoadInst *L) {
|
||||||
BasicBlock::iterator BBI = L, E = L->getParent()->end();
|
BasicBlock::iterator BBI = L, E = L->getParent()->end();
|
||||||
|
|
||||||
for (++BBI; BBI != E; ++BBI)
|
for (++BBI; BBI != E; ++BBI)
|
||||||
if (BBI->mayWriteToMemory())
|
if (BBI->mayWriteToMemory())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
// Check for non-address taken alloca. If not address-taken already, it isn't
|
||||||
|
// profitable to do this xform.
|
||||||
|
if (AllocaInst *AI = dyn_cast<AllocaInst>(L->getOperand(0))) {
|
||||||
|
bool isAddressTaken = false;
|
||||||
|
for (Value::use_iterator UI = AI->use_begin(), E = AI->use_end();
|
||||||
|
UI != E; ++UI) {
|
||||||
|
if (isa<LoadInst>(UI)) continue;
|
||||||
|
if (StoreInst *SI = dyn_cast<StoreInst>(*UI)) {
|
||||||
|
// If storing TO the alloca, then the address isn't taken.
|
||||||
|
if (SI->getOperand(1) == AI) continue;
|
||||||
|
}
|
||||||
|
isAddressTaken = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isAddressTaken)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user