mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-25 13:24:46 +00:00
Mark the x86 machine model as incomplete. PR17367.
Ideally, the machinel model is added at the time the instructions are defined. But many instructions in X86InstrSSE.td still need a model. Without this workaround the scheduler asserts because x86 already has itinerary classes for these instructions, indicating they should be modeled by the scheduler. Since we use the new machine model for other instructions, it expects a new machine model for these too. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@191391 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -174,6 +174,8 @@ public:
|
||||
unsigned MispredictPenalty;
|
||||
static const unsigned DefaultMispredictPenalty = 10;
|
||||
|
||||
bool CompleteModel;
|
||||
|
||||
private:
|
||||
unsigned ProcID;
|
||||
const MCProcResourceDesc *ProcResourceTable;
|
||||
@@ -194,6 +196,7 @@ public:
|
||||
LoadLatency(DefaultLoadLatency),
|
||||
HighLatency(DefaultHighLatency),
|
||||
MispredictPenalty(DefaultMispredictPenalty),
|
||||
CompleteModel(true),
|
||||
ProcID(0), ProcResourceTable(0), SchedClassTable(0),
|
||||
NumProcResourceKinds(0), NumSchedClasses(0),
|
||||
InstrItineraries(0) {
|
||||
@@ -203,19 +206,23 @@ public:
|
||||
|
||||
// Table-gen driven ctor.
|
||||
MCSchedModel(unsigned iw, int mbs, unsigned ll, unsigned hl,
|
||||
unsigned mp, unsigned pi, const MCProcResourceDesc *pr,
|
||||
unsigned mp, bool cm, unsigned pi, const MCProcResourceDesc *pr,
|
||||
const MCSchedClassDesc *sc, unsigned npr, unsigned nsc,
|
||||
const InstrItinerary *ii):
|
||||
IssueWidth(iw), MicroOpBufferSize(mbs), LoadLatency(ll), HighLatency(hl),
|
||||
MispredictPenalty(mp), ProcID(pi), ProcResourceTable(pr),
|
||||
SchedClassTable(sc), NumProcResourceKinds(npr), NumSchedClasses(nsc),
|
||||
InstrItineraries(ii) {}
|
||||
MispredictPenalty(mp), CompleteModel(cm), ProcID(pi),
|
||||
ProcResourceTable(pr), SchedClassTable(sc), NumProcResourceKinds(npr),
|
||||
NumSchedClasses(nsc), InstrItineraries(ii) {}
|
||||
|
||||
unsigned getProcessorID() const { return ProcID; }
|
||||
|
||||
/// Does this machine model include instruction-level scheduling.
|
||||
bool hasInstrSchedModel() const { return SchedClassTable; }
|
||||
|
||||
/// Return true if this machine model data for all instructions with a
|
||||
/// scheduling class (itinerary class or SchedRW list).
|
||||
bool isComplete() const { return CompleteModel; }
|
||||
|
||||
unsigned getNumProcResourceKinds() const {
|
||||
return NumProcResourceKinds;
|
||||
}
|
||||
|
Reference in New Issue
Block a user