diff options
author | Jakob Stoklund Olesen <stoklund@2pi.dk> | 2011-01-14 01:17:53 +0000 |
---|---|---|
committer | Jakob Stoklund Olesen <stoklund@2pi.dk> | 2011-01-14 01:17:53 +0000 |
commit | c0767e029da2ed84c1f76d0be53e2c65695e20d5 (patch) | |
tree | d405389cf26ed46356daaf2bbb28c8a2b2b99c9f /llvm/lib/CodeGen/MachineBasicBlock.cpp | |
parent | e3ed20ce9cf706eb1840c0ea79935d6652701535 (diff) | |
download | bcm5719-llvm-c0767e029da2ed84c1f76d0be53e2c65695e20d5.tar.gz bcm5719-llvm-c0767e029da2ed84c1f76d0be53e2c65695e20d5.zip |
Try again to teach getFirstTerminator() about debug values.
Fix some callers to better deal with debug values.
llvm-svn: 123419
Diffstat (limited to 'llvm/lib/CodeGen/MachineBasicBlock.cpp')
-rw-r--r-- | llvm/lib/CodeGen/MachineBasicBlock.cpp | 21 |
1 files changed, 16 insertions, 5 deletions
diff --git a/llvm/lib/CodeGen/MachineBasicBlock.cpp b/llvm/lib/CodeGen/MachineBasicBlock.cpp index ad1ab287e34..36963875f9e 100644 --- a/llvm/lib/CodeGen/MachineBasicBlock.cpp +++ b/llvm/lib/CodeGen/MachineBasicBlock.cpp @@ -155,11 +155,22 @@ MachineBasicBlock::SkipPHIsAndLabels(MachineBasicBlock::iterator I) { } MachineBasicBlock::iterator MachineBasicBlock::getFirstTerminator() { - iterator I = end(); - while (I != begin() && (--I)->getDesc().isTerminator()) - ; /*noop */ - if (I != end() && !I->getDesc().isTerminator()) ++I; - return I; + iterator B = begin(), I = end(); + iterator Term = I; + while (I != B) { + --I; + // Ignore any debug values after the first terminator. + if (I->isDebugValue()) + continue; + // Stop once we see a non-debug non-terminator. + if (!I->getDesc().isTerminator()) + break; + // Earliest terminator so far. + Term = I; + } + // Return the first terminator, or end(). + // Everything after Term is terminators and debug values. + return Term; } MachineBasicBlock::iterator MachineBasicBlock::getLastNonDebugInstr() { |