diff options
| author | Jakob Stoklund Olesen <stoklund@2pi.dk> | 2012-06-29 21:00:00 +0000 |
|---|---|---|
| committer | Jakob Stoklund Olesen <stoklund@2pi.dk> | 2012-06-29 21:00:00 +0000 |
| commit | da9ea1d6bc468127b72edef85552b57eac58d99d (patch) | |
| tree | ab76e028a42e4e51d66f7af5c4f96393a5416819 /llvm/lib/CodeGen | |
| parent | a33b078e7382b42c79a1c814bf709e8215f10cf0 (diff) | |
| download | bcm5719-llvm-da9ea1d6bc468127b72edef85552b57eac58d99d.tar.gz bcm5719-llvm-da9ea1d6bc468127b72edef85552b57eac58d99d.zip | |
Check for extra kill flags on live-out virtual registers.
This would previously get reported as the misleading "Virtual register
def doesn't dominate all uses."
llvm-svn: 159460
Diffstat (limited to 'llvm/lib/CodeGen')
| -rw-r--r-- | llvm/lib/CodeGen/MachineVerifier.cpp | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/MachineVerifier.cpp b/llvm/lib/CodeGen/MachineVerifier.cpp index a443b51d15e..45ce3ab28b5 100644 --- a/llvm/lib/CodeGen/MachineVerifier.cpp +++ b/llvm/lib/CodeGen/MachineVerifier.cpp @@ -1049,6 +1049,20 @@ void MachineVerifier::visitMachineFunctionAfter() { // Now check liveness info if available calcRegsRequired(); + // Check for killed virtual registers that should be live out. + for (MachineFunction::const_iterator MFI = MF->begin(), MFE = MF->end(); + MFI != MFE; ++MFI) { + BBInfo &MInfo = MBBInfoMap[MFI]; + for (RegSet::iterator + I = MInfo.vregsRequired.begin(), E = MInfo.vregsRequired.end(); I != E; + ++I) + if (MInfo.regsKilled.count(*I)) { + report("Virtual register killed in block, but needed live out.", MFI); + *OS << "Virtual register " << PrintReg(*I) + << " is used after the block.\n"; + } + } + if (!MF->empty()) { BBInfo &MInfo = MBBInfoMap[&MF->front()]; for (RegSet::iterator |

