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/CodeGen/DFAPacketizer.cpp | |
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/CodeGen/DFAPacketizer.cpp')
-rw-r--r-- | llvm/lib/CodeGen/DFAPacketizer.cpp | 39 |
1 files changed, 9 insertions, 30 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]; |