mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-12-15 07:39:31 +00:00
Fix the inline cost calculation to take into account instructions
which cannot be folded even if they have constant operands. Significantly helps if_spppsubr.c attached to PR4573. llvm-svn: 76285
This commit is contained in:
parent
c0d63a2fec
commit
b5b88b60b3
@ -42,6 +42,13 @@ unsigned InlineCostAnalyzer::FunctionInfo::
|
||||
// Figure out if this instruction will be removed due to simple constant
|
||||
// propagation.
|
||||
Instruction &Inst = cast<Instruction>(**UI);
|
||||
|
||||
// We can't constant propagate instructions which have effects or
|
||||
// read memory.
|
||||
if (Inst.mayReadFromMemory() || Inst.mayHaveSideEffects() ||
|
||||
isa<AllocationInst>(Inst))
|
||||
continue;
|
||||
|
||||
bool AllOperandsConstant = true;
|
||||
for (unsigned i = 0, e = Inst.getNumOperands(); i != e; ++i)
|
||||
if (!isa<Constant>(Inst.getOperand(i)) && Inst.getOperand(i) != V) {
|
||||
|
Loading…
Reference in New Issue
Block a user