diff options
| author | Evan Cheng <evan.cheng@apple.com> | 2011-12-14 02:11:42 +0000 | 
|---|---|---|
| committer | Evan Cheng <evan.cheng@apple.com> | 2011-12-14 02:11:42 +0000 | 
| commit | 7fae11b23181d048417a521aa8adaaec318a91c0 (patch) | |
| tree | f3d795816e99278225610b799cbc7f95da8f477d /llvm/lib/CodeGen/MachineVerifier.cpp | |
| parent | 87ebe63542e980e332ba4c61ad6d78654ae4c90a (diff) | |
| download | llvm-7fae11b23181d048417a521aa8adaaec318a91c0.zip llvm-7fae11b23181d048417a521aa8adaaec318a91c0.tar.gz llvm-7fae11b23181d048417a521aa8adaaec318a91c0.tar.bz2  | |
- Add MachineInstrBundle.h and MachineInstrBundle.cpp. This includes a function
  to finalize MI bundles (i.e. add BUNDLE instruction and computing register def
  and use lists of the BUNDLE instruction) and a pass to unpack bundles.
- Teach more of MachineBasic and MachineInstr methods to be bundle aware.
- Switch Thumb2 IT block to MI bundles and delete the hazard recognizer hack to
  prevent IT blocks from being broken apart.
llvm-svn: 146542
Diffstat (limited to 'llvm/lib/CodeGen/MachineVerifier.cpp')
| -rw-r--r-- | llvm/lib/CodeGen/MachineVerifier.cpp | 8 | 
1 files changed, 6 insertions, 2 deletions
diff --git a/llvm/lib/CodeGen/MachineVerifier.cpp b/llvm/lib/CodeGen/MachineVerifier.cpp index 1abc61b..0a2c2f8 100644 --- a/llvm/lib/CodeGen/MachineVerifier.cpp +++ b/llvm/lib/CodeGen/MachineVerifier.cpp @@ -279,13 +279,17 @@ bool MachineVerifier::runOnMachineFunction(MachineFunction &MF) {    for (MachineFunction::const_iterator MFI = MF.begin(), MFE = MF.end();         MFI!=MFE; ++MFI) {      visitMachineBasicBlockBefore(MFI); -    for (MachineBasicBlock::const_iterator MBBI = MFI->begin(), -           MBBE = MFI->end(); MBBI != MBBE; ++MBBI) { +    for (MachineBasicBlock::const_instr_iterator MBBI = MFI->instr_begin(), +           MBBE = MFI->instr_end(); MBBI != MBBE; ++MBBI) {        if (MBBI->getParent() != MFI) {          report("Bad instruction parent pointer", MFI);          *OS << "Instruction: " << *MBBI;          continue;        } +      // Skip BUNDLE instruction for now. FIXME: We should add code to verify +      // the BUNDLE's specifically. +      if (MBBI->isBundle()) +        continue;        visitMachineInstrBefore(MBBI);        for (unsigned I = 0, E = MBBI->getNumOperands(); I != E; ++I)          visitMachineOperand(&MBBI->getOperand(I), I);  | 
