mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-19 20:34:38 +00:00
Fix a case where LSR is sensitive to debug info.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@97830 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
a79eb387ac
commit
8d50ea7603
@ -15,6 +15,7 @@
|
||||
|
||||
#include "llvm/Analysis/ScalarEvolutionExpander.h"
|
||||
#include "llvm/Analysis/LoopInfo.h"
|
||||
#include "llvm/IntrinsicInst.h"
|
||||
#include "llvm/LLVMContext.h"
|
||||
#include "llvm/Target/TargetData.h"
|
||||
#include "llvm/ADT/STLExtras.h"
|
||||
@ -137,6 +138,10 @@ Value *SCEVExpander::InsertBinop(Instruction::BinaryOps Opcode,
|
||||
if (IP != BlockBegin) {
|
||||
--IP;
|
||||
for (; ScanLimit; --IP, --ScanLimit) {
|
||||
// Don't count dbg.value against the ScanLimit, to avoid perturbing the
|
||||
// generated code.
|
||||
if (isa<DbgInfoIntrinsic>(IP))
|
||||
ScanLimit++;
|
||||
if (IP->getOpcode() == (unsigned)Opcode && IP->getOperand(0) == LHS &&
|
||||
IP->getOperand(1) == RHS)
|
||||
return IP;
|
||||
@ -505,6 +510,10 @@ Value *SCEVExpander::expandAddToGEP(const SCEV *const *op_begin,
|
||||
if (IP != BlockBegin) {
|
||||
--IP;
|
||||
for (; ScanLimit; --IP, --ScanLimit) {
|
||||
// Don't count dbg.value against the ScanLimit, to avoid perturbing the
|
||||
// generated code.
|
||||
if (isa<DbgInfoIntrinsic>(IP))
|
||||
ScanLimit++;
|
||||
if (IP->getOpcode() == Instruction::GetElementPtr &&
|
||||
IP->getOperand(0) == V && IP->getOperand(1) == Idx)
|
||||
return IP;
|
||||
|
Loading…
x
Reference in New Issue
Block a user