Add annotations to tablegen-generated processor itineraries, or replace them with something meaningful. I want to be able to read and debug the generated tables.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@128703 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Andrew Trick 2011-04-01 02:22:47 +00:00
parent da96cf2029
commit 234823297e
2 changed files with 21 additions and 16 deletions

View File

@ -342,7 +342,6 @@ void SubtargetEmitter::EmitStageAndOperandCycleData(raw_ostream &OS,
BypassTable += " 0, // No itinerary\n"; BypassTable += " 0, // No itinerary\n";
unsigned StageCount = 1, OperandCycleCount = 1; unsigned StageCount = 1, OperandCycleCount = 1;
unsigned ItinStageEnum = 1, ItinOperandCycleEnum = 1;
std::map<std::string, unsigned> ItinStageMap, ItinOperandMap; std::map<std::string, unsigned> ItinStageMap, ItinOperandMap;
for (unsigned i = 0, N = ProcItinList.size(); i < N; i++) { for (unsigned i = 0, N = ProcItinList.size(); i < N; i++) {
// Next record // Next record
@ -386,12 +385,14 @@ void SubtargetEmitter::EmitStageAndOperandCycleData(raw_ostream &OS,
if (NStages > 0) { if (NStages > 0) {
FindStage = ItinStageMap[ItinStageString]; FindStage = ItinStageMap[ItinStageString];
if (FindStage == 0) { if (FindStage == 0) {
// Emit as { cycles, u1 | u2 | ... | un, timeinc }, // index // Emit as { cycles, u1 | u2 | ... | un, timeinc }, // indices
StageTable += ItinStageString + ", // " + itostr(ItinStageEnum) + "\n"; StageTable += ItinStageString + ", // " + itostr(StageCount);
if (NStages > 1)
StageTable += "-" + itostr(StageCount + NStages - 1);
StageTable += "\n";
// Record Itin class number. // Record Itin class number.
ItinStageMap[ItinStageString] = FindStage = StageCount; ItinStageMap[ItinStageString] = FindStage = StageCount;
StageCount += NStages; StageCount += NStages;
ItinStageEnum++;
} }
} }
@ -402,18 +403,18 @@ void SubtargetEmitter::EmitStageAndOperandCycleData(raw_ostream &OS,
FindOperandCycle = ItinOperandMap[ItinOperandString]; FindOperandCycle = ItinOperandMap[ItinOperandString];
if (FindOperandCycle == 0) { if (FindOperandCycle == 0) {
// Emit as cycle, // index // Emit as cycle, // index
OperandCycleTable += ItinOperandCycleString + ", // " + OperandCycleTable += ItinOperandCycleString + ", // ";
itostr(ItinOperandCycleEnum) + "\n"; std::string OperandIdxComment = itostr(OperandCycleCount);
if (NOperandCycles > 1)
OperandIdxComment += "-"
+ itostr(OperandCycleCount + NOperandCycles - 1);
OperandCycleTable += OperandIdxComment + "\n";
// Record Itin class number. // Record Itin class number.
ItinOperandMap[ItinOperandCycleString] = ItinOperandMap[ItinOperandCycleString] =
FindOperandCycle = OperandCycleCount; FindOperandCycle = OperandCycleCount;
// Emit as bypass, // index // Emit as bypass, // index
BypassTable += ItinBypassString + ", // " + BypassTable += ItinBypassString + ", // " + OperandIdxComment + "\n";
itostr(ItinOperandCycleEnum) + "\n";
OperandCycleCount += NOperandCycles; OperandCycleCount += NOperandCycles;
ItinOperandCycleEnum++;
} }
} }
@ -461,7 +462,9 @@ void SubtargetEmitter::EmitStageAndOperandCycleData(raw_ostream &OS,
// //
// EmitProcessorData - Generate data for processor itineraries. // EmitProcessorData - Generate data for processor itineraries.
// //
void SubtargetEmitter::EmitProcessorData(raw_ostream &OS, void SubtargetEmitter::
EmitProcessorData(raw_ostream &OS,
std::vector<Record*> &ItinClassList,
std::vector<std::vector<InstrItinerary> > &ProcList) { std::vector<std::vector<InstrItinerary> > &ProcList) {
// Get an iterator for processor itinerary stages // Get an iterator for processor itinerary stages
std::vector<std::vector<InstrItinerary> >::iterator std::vector<std::vector<InstrItinerary> >::iterator
@ -486,6 +489,7 @@ void SubtargetEmitter::EmitProcessorData(raw_ostream &OS,
// For each itinerary class // For each itinerary class
std::vector<InstrItinerary> &ItinList = *ProcListIter++; std::vector<InstrItinerary> &ItinList = *ProcListIter++;
assert(ItinList.size() == ItinClassList.size() && "bad itinerary");
for (unsigned j = 0, M = ItinList.size(); j < M; ++j) { for (unsigned j = 0, M = ItinList.size(); j < M; ++j) {
InstrItinerary &Intinerary = ItinList[j]; InstrItinerary &Intinerary = ItinList[j];
@ -502,7 +506,7 @@ void SubtargetEmitter::EmitProcessorData(raw_ostream &OS,
Intinerary.LastOperandCycle << " }"; Intinerary.LastOperandCycle << " }";
} }
OS << ", // " << j << "\n"; OS << ", // " << j << " " << ItinClassList[j]->getName() << "\n";
} }
// End processor itinerary table // End processor itinerary table
@ -579,7 +583,7 @@ void SubtargetEmitter::EmitData(raw_ostream &OS) {
EmitStageAndOperandCycleData(OS, NItinClasses, ItinClassesMap, EmitStageAndOperandCycleData(OS, NItinClasses, ItinClassesMap,
ItinClassList, ProcList); ItinClassList, ProcList);
// Emit the processor itinerary data // Emit the processor itinerary data
EmitProcessorData(OS, ProcList); EmitProcessorData(OS, ItinClassList, ProcList);
// Emit the processor lookup data // Emit the processor lookup data
EmitProcessorLookup(OS); EmitProcessorLookup(OS);
} }

View File

@ -48,6 +48,7 @@ class SubtargetEmitter : public TableGenBackend {
std::vector<Record*> &ItinClassList, std::vector<Record*> &ItinClassList,
std::vector<std::vector<InstrItinerary> > &ProcList); std::vector<std::vector<InstrItinerary> > &ProcList);
void EmitProcessorData(raw_ostream &OS, void EmitProcessorData(raw_ostream &OS,
std::vector<Record*> &ItinClassList,
std::vector<std::vector<InstrItinerary> > &ProcList); std::vector<std::vector<InstrItinerary> > &ProcList);
void EmitProcessorLookup(raw_ostream &OS); void EmitProcessorLookup(raw_ostream &OS);
void EmitData(raw_ostream &OS); void EmitData(raw_ostream &OS);