forked from OSchip/llvm-project
Move findDebugLoc somewhere more central. Fix
more cases where debug declarations affect debug line info. llvm-svn: 93953
This commit is contained in:
parent
c0943d089f
commit
91970b4ea2
|
@ -367,6 +367,9 @@ private: // Methods used to maintain doubly linked list of blocks...
|
|||
void removePredecessor(MachineBasicBlock *pred);
|
||||
};
|
||||
|
||||
DebugLoc
|
||||
findDebugLoc(MachineBasicBlock::iterator &MBBI, MachineBasicBlock &MBB);
|
||||
|
||||
raw_ostream& operator<<(raw_ostream &OS, const MachineBasicBlock &MBB);
|
||||
|
||||
void WriteAsOperand(raw_ostream &, const MachineBasicBlock*, bool t);
|
||||
|
|
|
@ -528,3 +528,20 @@ void llvm::WriteAsOperand(raw_ostream &OS, const MachineBasicBlock *MBB,
|
|||
bool t) {
|
||||
OS << "BB#" << MBB->getNumber();
|
||||
}
|
||||
|
||||
/// findDebugLoc - find the next valid DebugLoc starting at MBBI, skipping
|
||||
/// any DEBUG_VALUE instructions. Return UnknownLoc if there is none.
|
||||
DebugLoc
|
||||
llvm::findDebugLoc(MachineBasicBlock::iterator &MBBI, MachineBasicBlock &MBB) {
|
||||
DebugLoc DL;
|
||||
if (MBBI != MBB.end()) {
|
||||
// Skip debug declarations, we don't want a DebugLoc from them.
|
||||
MachineBasicBlock::iterator MBBI2 = MBBI;
|
||||
while (MBBI2 != MBB.end() &&
|
||||
MBBI2->getOpcode()==TargetInstrInfo::DEBUG_VALUE)
|
||||
MBBI2++;
|
||||
if (MBBI2 != MBB.end())
|
||||
DL = MBBI2->getDebugLoc();
|
||||
}
|
||||
return DL;
|
||||
}
|
||||
|
|
|
@ -2200,8 +2200,7 @@ bool X86InstrInfo::spillCalleeSavedRegisters(MachineBasicBlock &MBB,
|
|||
if (CSI.empty())
|
||||
return false;
|
||||
|
||||
DebugLoc DL = DebugLoc::getUnknownLoc();
|
||||
if (MI != MBB.end()) DL = MI->getDebugLoc();
|
||||
DebugLoc DL = findDebugLoc(MI, MBB);
|
||||
|
||||
bool is64Bit = TM.getSubtarget<X86Subtarget>().is64Bit();
|
||||
bool isWin64 = TM.getSubtarget<X86Subtarget>().isTargetWin64();
|
||||
|
@ -2239,8 +2238,7 @@ bool X86InstrInfo::restoreCalleeSavedRegisters(MachineBasicBlock &MBB,
|
|||
if (CSI.empty())
|
||||
return false;
|
||||
|
||||
DebugLoc DL = DebugLoc::getUnknownLoc();
|
||||
if (MI != MBB.end()) DL = MI->getDebugLoc();
|
||||
DebugLoc DL = findDebugLoc(MI, MBB);
|
||||
|
||||
MachineFunction &MF = *MBB.getParent();
|
||||
unsigned FPReg = RI.getFrameRegister(MF);
|
||||
|
|
|
@ -666,23 +666,6 @@ X86RegisterInfo::processFunctionBeforeCalleeSavedScan(MachineFunction &MF,
|
|||
}
|
||||
}
|
||||
|
||||
/// findDebugLoc - find the next valid DebugLoc starting at MBBI, skipping
|
||||
/// any DEBUG_VALUE instructions. Return UnknownLoc if there is none.
|
||||
static
|
||||
DebugLoc findDebugLoc(MachineBasicBlock::iterator &MBBI, MachineBasicBlock &MBB) {
|
||||
DebugLoc DL;
|
||||
if (MBBI != MBB.end()) {
|
||||
// Skip debug declarations, we don't want a DebugLoc from them.
|
||||
MachineBasicBlock::iterator MBBI2 = MBBI;
|
||||
while (MBBI2 != MBB.end() &&
|
||||
MBBI2->getOpcode()==TargetInstrInfo::DEBUG_VALUE)
|
||||
MBBI2++;
|
||||
if (MBBI2 != MBB.end())
|
||||
DL = MBBI2->getDebugLoc();
|
||||
}
|
||||
return DL;
|
||||
}
|
||||
|
||||
/// emitSPUpdate - Emit a series of instructions to increment / decrement the
|
||||
/// stack pointer by a constant value.
|
||||
static
|
||||
|
|
Loading…
Reference in New Issue