diff options
| author | Krzysztof Parzyszek <kparzysz@codeaurora.org> | 2015-11-21 17:38:33 +0000 | 
|---|---|---|
| committer | Krzysztof Parzyszek <kparzysz@codeaurora.org> | 2015-11-21 17:38:33 +0000 | 
| commit | 4ca21fc1aa7c6261eacde2ce203819060d9bdde8 (patch) | |
| tree | ad234b70a696bb54c2d92f714d8716134773fc83 /llvm/lib | |
| parent | 220a9bc0188ca5c1377c8ffef8d794b78f610bb3 (diff) | |
| download | bcm5719-llvm-4ca21fc1aa7c6261eacde2ce203819060d9bdde8.tar.gz bcm5719-llvm-4ca21fc1aa7c6261eacde2ce203819060d9bdde8.zip  | |
Revert r253790: it breaks all builds for some reason.
llvm-svn: 253791
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/CodeGen/DFAPacketizer.cpp | 39 | ||||
| -rw-r--r-- | llvm/lib/Target/Hexagon/HexagonScheduleV60.td | 9 | 
2 files changed, 9 insertions, 39 deletions
diff --git a/llvm/lib/CodeGen/DFAPacketizer.cpp b/llvm/lib/CodeGen/DFAPacketizer.cpp index 40450b46fcb..ee50f972aa7 100644 --- a/llvm/lib/CodeGen/DFAPacketizer.cpp +++ b/llvm/lib/CodeGen/DFAPacketizer.cpp @@ -31,17 +31,10 @@  #include "llvm/Target/TargetInstrInfo.h"  using namespace llvm; -DFAPacketizer::DFAPacketizer(const InstrItineraryData *I, -                             const DFAStateInput (*SIT)[2], +DFAPacketizer::DFAPacketizer(const InstrItineraryData *I, const int (*SIT)[2],                               const unsigned *SET):    InstrItins(I), CurrentState(0), DFAStateInputTable(SIT), -  DFAStateEntryTable(SET) { -  // Make sure DFA types are large enough for the number of terms & resources. -  assert((DFA_MAX_RESTERMS * DFA_MAX_RESOURCES) <= (8 * sizeof(DFAInput)) -        && "(DFA_MAX_RESTERMS * DFA_MAX_RESOURCES) too big for DFAInput"); -  assert((DFA_MAX_RESTERMS * DFA_MAX_RESOURCES) <= (8 * sizeof(DFAStateInput)) -        && "(DFA_MAX_RESTERMS * DFA_MAX_RESOURCES) too big for DFAStateInput"); -} +  DFAStateEntryTable(SET) {}  // @@ -67,40 +60,26 @@ void DFAPacketizer::ReadTable(unsigned int state) {        DFAStateInputTable[i][1];  } -// -// getInsnInput - Return the DFAInput for an instruction class. -// -DFAInput DFAPacketizer::getInsnInput(unsigned InsnClass) { -  // note: this logic must match that in DFAPacketizer.h for input vectors -  DFAInput InsnInput = 0; -  unsigned i = 0; -  for (const InstrStage *IS = InstrItins->beginStage(InsnClass), -        *IE = InstrItins->endStage(InsnClass); IS != IE; ++IS, ++i) { -    unsigned FuncUnits = IS->getUnits(); -    InsnInput <<= DFA_MAX_RESOURCES;  // Shift over any previous AND'ed terms. -    InsnInput |= FuncUnits; -    assert ((i < DFA_MAX_RESTERMS) && "Exceeded maximum number of DFA inputs"); -  } - -  return InsnInput; -}  // canReserveResources - Check if the resources occupied by a MCInstrDesc  // are available in the current state.  bool DFAPacketizer::canReserveResources(const llvm::MCInstrDesc *MID) {    unsigned InsnClass = MID->getSchedClass(); -  DFAInput InsnInput = getInsnInput(InsnClass); -  UnsignPair StateTrans = UnsignPair(CurrentState, InsnInput); +  const llvm::InstrStage *IS = InstrItins->beginStage(InsnClass); +  unsigned FuncUnits = IS->getUnits(); +  UnsignPair StateTrans = UnsignPair(CurrentState, FuncUnits);    ReadTable(CurrentState);    return (CachedTable.count(StateTrans) != 0);  } +  // reserveResources - Reserve the resources occupied by a MCInstrDesc and  // change the current state to reflect that change.  void DFAPacketizer::reserveResources(const llvm::MCInstrDesc *MID) {    unsigned InsnClass = MID->getSchedClass(); -  DFAInput InsnInput = getInsnInput(InsnClass); -  UnsignPair StateTrans = UnsignPair(CurrentState, InsnInput); +  const llvm::InstrStage *IS = InstrItins->beginStage(InsnClass); +  unsigned FuncUnits = IS->getUnits(); +  UnsignPair StateTrans = UnsignPair(CurrentState, FuncUnits);    ReadTable(CurrentState);    assert(CachedTable.count(StateTrans) != 0);    CurrentState = CachedTable[StateTrans]; diff --git a/llvm/lib/Target/Hexagon/HexagonScheduleV60.td b/llvm/lib/Target/Hexagon/HexagonScheduleV60.td index 2ccff8242a4..7cda4a74319 100644 --- a/llvm/lib/Target/Hexagon/HexagonScheduleV60.td +++ b/llvm/lib/Target/Hexagon/HexagonScheduleV60.td @@ -20,15 +20,6 @@ def CVI_XLSHF  : FuncUnit;  def CVI_MPY01  : FuncUnit;  def CVI_ALL    : FuncUnit; -// Combined functional unit data. -def HexagonComboFuncsV60 : -    ComboFuncUnits<[ -      ComboFuncData<CVI_XLSHF    , [CVI_XLANE, CVI_SHIFT]>, -      ComboFuncData<CVI_MPY01    , [CVI_MPY0, CVI_MPY1]>, -      ComboFuncData<CVI_ALL      , [CVI_ST, CVI_XLANE, CVI_SHIFT, -                                    CVI_MPY0, CVI_MPY1, CVI_LD]> -    ]>; -  // Note: When adding additional vector scheduling classes, add the  // corresponding methods to the class HexagonInstrInfo.  def CVI_VA           : InstrItinClass;  | 

