diff options
Diffstat (limited to 'llvm/lib/CodeGen')
| -rw-r--r-- | llvm/lib/CodeGen/MachineCombiner.cpp | 2 | ||||
| -rw-r--r-- | llvm/lib/CodeGen/TargetInstrInfo.cpp | 39 | 
2 files changed, 25 insertions, 16 deletions
| diff --git a/llvm/lib/CodeGen/MachineCombiner.cpp b/llvm/lib/CodeGen/MachineCombiner.cpp index bfa5a6afc5f..11b6a79a8b1 100644 --- a/llvm/lib/CodeGen/MachineCombiner.cpp +++ b/llvm/lib/CodeGen/MachineCombiner.cpp @@ -336,7 +336,7 @@ bool MachineCombiner::combineInstructions(MachineBasicBlock *MBB) {      auto &MI = *BlockIter++;      DEBUG(dbgs() << "INSTR "; MI.dump(); dbgs() << "\n";); -    SmallVector<MachineCombinerPattern::MC_PATTERN, 16> Patterns; +    SmallVector<MachineCombinerPattern, 16> Patterns;      // The motivating example is:      //      //     MUL  Other        MUL_op1 MUL_op2  Other diff --git a/llvm/lib/CodeGen/TargetInstrInfo.cpp b/llvm/lib/CodeGen/TargetInstrInfo.cpp index 44d3b61c9f1..6eaf991ac70 100644 --- a/llvm/lib/CodeGen/TargetInstrInfo.cpp +++ b/llvm/lib/CodeGen/TargetInstrInfo.cpp @@ -636,7 +636,7 @@ bool TargetInstrInfo::isReassociationCandidate(const MachineInstr &Inst,  //    that pattern.  bool TargetInstrInfo::getMachineCombinerPatterns(      MachineInstr &Root, -    SmallVectorImpl<MachineCombinerPattern::MC_PATTERN> &Patterns) const { +    SmallVectorImpl<MachineCombinerPattern> &Patterns) const {    bool Commute;    if (isReassociationCandidate(Root, Commute)) { @@ -645,11 +645,11 @@ bool TargetInstrInfo::getMachineCombinerPatterns(      // possibility for the Prev instruction in the sequence and let the      // machine combiner decide if changing the operands is worthwhile.      if (Commute) { -      Patterns.push_back(MachineCombinerPattern::MC_REASSOC_AX_YB); -      Patterns.push_back(MachineCombinerPattern::MC_REASSOC_XA_YB); +      Patterns.push_back(MachineCombinerPattern::REASSOC_AX_YB); +      Patterns.push_back(MachineCombinerPattern::REASSOC_XA_YB);      } else { -      Patterns.push_back(MachineCombinerPattern::MC_REASSOC_AX_BY); -      Patterns.push_back(MachineCombinerPattern::MC_REASSOC_XA_BY); +      Patterns.push_back(MachineCombinerPattern::REASSOC_AX_BY); +      Patterns.push_back(MachineCombinerPattern::REASSOC_XA_BY);      }      return true;    } @@ -661,7 +661,7 @@ bool TargetInstrInfo::getMachineCombinerPatterns(  /// See the above comments before getMachineCombinerPatterns().  void TargetInstrInfo::reassociateOps(      MachineInstr &Root, MachineInstr &Prev, -    MachineCombinerPattern::MC_PATTERN Pattern, +    MachineCombinerPattern Pattern,      SmallVectorImpl<MachineInstr *> &InsInstrs,      SmallVectorImpl<MachineInstr *> &DelInstrs,      DenseMap<unsigned, unsigned> &InstrIdxForVirtReg) const { @@ -681,10 +681,19 @@ void TargetInstrInfo::reassociateOps(      { 2, 2, 1, 1 }    }; -  MachineOperand &OpA = Prev.getOperand(OpIdx[Pattern][0]); -  MachineOperand &OpB = Root.getOperand(OpIdx[Pattern][1]); -  MachineOperand &OpX = Prev.getOperand(OpIdx[Pattern][2]); -  MachineOperand &OpY = Root.getOperand(OpIdx[Pattern][3]); +  int Row; +  switch (Pattern) { +  case MachineCombinerPattern::REASSOC_AX_BY: Row = 0; break; +  case MachineCombinerPattern::REASSOC_AX_YB: Row = 1; break; +  case MachineCombinerPattern::REASSOC_XA_BY: Row = 2; break; +  case MachineCombinerPattern::REASSOC_XA_YB: Row = 3; break; +  default: llvm_unreachable("unexpected MachineCombinerPattern"); +  } + +  MachineOperand &OpA = Prev.getOperand(OpIdx[Row][0]); +  MachineOperand &OpB = Root.getOperand(OpIdx[Row][1]); +  MachineOperand &OpX = Prev.getOperand(OpIdx[Row][2]); +  MachineOperand &OpY = Root.getOperand(OpIdx[Row][3]);    MachineOperand &OpC = Root.getOperand(0);    unsigned RegA = OpA.getReg(); @@ -735,7 +744,7 @@ void TargetInstrInfo::reassociateOps(  }  void TargetInstrInfo::genAlternativeCodeSequence( -    MachineInstr &Root, MachineCombinerPattern::MC_PATTERN Pattern, +    MachineInstr &Root, MachineCombinerPattern Pattern,      SmallVectorImpl<MachineInstr *> &InsInstrs,      SmallVectorImpl<MachineInstr *> &DelInstrs,      DenseMap<unsigned, unsigned> &InstIdxForVirtReg) const { @@ -744,12 +753,12 @@ void TargetInstrInfo::genAlternativeCodeSequence(    // Select the previous instruction in the sequence based on the input pattern.    MachineInstr *Prev = nullptr;    switch (Pattern) { -  case MachineCombinerPattern::MC_REASSOC_AX_BY: -  case MachineCombinerPattern::MC_REASSOC_XA_BY: +  case MachineCombinerPattern::REASSOC_AX_BY: +  case MachineCombinerPattern::REASSOC_XA_BY:      Prev = MRI.getUniqueVRegDef(Root.getOperand(1).getReg());      break; -  case MachineCombinerPattern::MC_REASSOC_AX_YB: -  case MachineCombinerPattern::MC_REASSOC_XA_YB: +  case MachineCombinerPattern::REASSOC_AX_YB: +  case MachineCombinerPattern::REASSOC_XA_YB:      Prev = MRI.getUniqueVRegDef(Root.getOperand(2).getReg());      break;    default: | 

