Fix generation of multi-stage instruction itineraries. Patch by

giuma.cordes@gmail.com

llvm-svn: 49276
This commit is contained in:
Chris Lattner 2008-04-06 17:38:14 +00:00
parent 7cd3a341c4
commit a8d3c512dd

View File

@ -272,6 +272,7 @@ void SubtargetEmitter::EmitStageData(std::ostream &OS,
OS << "static const llvm::InstrStage Stages[] = {\n" OS << "static const llvm::InstrStage Stages[] = {\n"
" { 0, 0 }, // No itinerary\n"; " { 0, 0 }, // No itinerary\n";
unsigned StageCount = 1;
unsigned ItinEnum = 1; unsigned ItinEnum = 1;
std::map<std::string, unsigned> ItinMap; std::map<std::string, unsigned> ItinMap;
for (unsigned i = 0, N = ProcItinList.size(); i < N; i++) { for (unsigned i = 0, N = ProcItinList.size(); i < N; i++) {
@ -308,8 +309,10 @@ void SubtargetEmitter::EmitStageData(std::ostream &OS,
if (Find == 0) { if (Find == 0) {
// Emit as { cycles, u1 | u2 | ... | un }, // index // Emit as { cycles, u1 | u2 | ... | un }, // index
OS << ItinString << ", // " << ItinEnum << "\n"; OS << ItinString << ", // " << ItinEnum << "\n";
// Record Itin class number // Record Itin class number.
ItinMap[ItinString] = Find = ItinEnum++; ItinMap[ItinString] = Find = StageCount;
StageCount += NStages;
ItinEnum++;
} }
// Set up itinerary as location and location + stage count // Set up itinerary as location and location + stage count