diff options
Diffstat (limited to 'lib/Target/ARM/ARMInstructionSelector.cpp')
| -rw-r--r-- | lib/Target/ARM/ARMInstructionSelector.cpp | 23 | 
1 files changed, 23 insertions, 0 deletions
| diff --git a/lib/Target/ARM/ARMInstructionSelector.cpp b/lib/Target/ARM/ARMInstructionSelector.cpp index 29ef69ad0010f..faed6b867e2bc 100644 --- a/lib/Target/ARM/ARMInstructionSelector.cpp +++ b/lib/Target/ARM/ARMInstructionSelector.cpp @@ -722,6 +722,29 @@ bool ARMInstructionSelector::select(MachineInstr &I) const {        return false;      break;    } +  case G_BRCOND: { +    if (!validReg(MRI, I.getOperand(0).getReg(), 1, ARM::GPRRegBankID)) { +      DEBUG(dbgs() << "Unsupported condition register for G_BRCOND"); +      return false; +    } + +    // Set the flags. +    auto Test = BuildMI(*I.getParent(), I, I.getDebugLoc(), TII.get(ARM::TSTri)) +                    .addReg(I.getOperand(0).getReg()) +                    .addImm(1) +                    .add(predOps(ARMCC::AL)); +    if (!constrainSelectedInstRegOperands(*Test, TII, TRI, RBI)) +      return false; + +    // Branch conditionally. +    auto Branch = BuildMI(*I.getParent(), I, I.getDebugLoc(), TII.get(ARM::Bcc)) +                      .add(I.getOperand(1)) +                      .add(predOps(ARMCC::EQ, ARM::CPSR)); +    if (!constrainSelectedInstRegOperands(*Branch, TII, TRI, RBI)) +      return false; +    I.eraseFromParent(); +    return true; +  }    default:      return false;    } | 
