mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-16 14:31:59 +00:00
further simplifications and cleanup
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@45643 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
951740afb4
commit
ef8339b11a
@ -27,6 +27,33 @@ void InstrInfoEmitter::printDefList(const std::vector<Record*> &Uses,
|
|||||||
OS << "0 };\n";
|
OS << "0 };\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
// Instruction Itinerary Information.
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
struct RecordNameComparator {
|
||||||
|
bool operator()(const Record *Rec1, const Record *Rec2) const {
|
||||||
|
return Rec1->getName() < Rec2->getName();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
void InstrInfoEmitter::GatherItinClasses() {
|
||||||
|
std::vector<Record*> DefList =
|
||||||
|
Records.getAllDerivedDefinitions("InstrItinClass");
|
||||||
|
std::sort(DefList.begin(), DefList.end(), RecordNameComparator());
|
||||||
|
|
||||||
|
for (unsigned i = 0, N = DefList.size(); i < N; i++)
|
||||||
|
ItinClassMap[DefList[i]->getName()] = i;
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned InstrInfoEmitter::getItinClassNumber(const Record *InstRec) {
|
||||||
|
return ItinClassMap[InstRec->getValueAsDef("Itinerary")->getName()];
|
||||||
|
}
|
||||||
|
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
// Operand Info Emission.
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
std::vector<std::string>
|
std::vector<std::string>
|
||||||
InstrInfoEmitter::GetOperandInfo(const CodeGenInstruction &Inst) {
|
InstrInfoEmitter::GetOperandInfo(const CodeGenInstruction &Inst) {
|
||||||
std::vector<std::string> Result;
|
std::vector<std::string> Result;
|
||||||
@ -88,6 +115,31 @@ InstrInfoEmitter::GetOperandInfo(const CodeGenInstruction &Inst) {
|
|||||||
return Result;
|
return Result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void InstrInfoEmitter::EmitOperandInfo(std::ostream &OS,
|
||||||
|
OperandInfoMapTy &OperandInfoIDs) {
|
||||||
|
// ID #0 is for no operand info.
|
||||||
|
unsigned OperandListNum = 0;
|
||||||
|
OperandInfoIDs[std::vector<std::string>()] = ++OperandListNum;
|
||||||
|
|
||||||
|
OS << "\n";
|
||||||
|
const CodeGenTarget &Target = CDP.getTargetInfo();
|
||||||
|
for (CodeGenTarget::inst_iterator II = Target.inst_begin(),
|
||||||
|
E = Target.inst_end(); II != E; ++II) {
|
||||||
|
std::vector<std::string> OperandInfo = GetOperandInfo(II->second);
|
||||||
|
unsigned &N = OperandInfoIDs[OperandInfo];
|
||||||
|
if (N != 0) continue;
|
||||||
|
|
||||||
|
N = ++OperandListNum;
|
||||||
|
OS << "static const TargetOperandInfo OperandInfo" << N << "[] = { ";
|
||||||
|
for (unsigned i = 0, e = OperandInfo.size(); i != e; ++i)
|
||||||
|
OS << "{ " << OperandInfo[i] << " }, ";
|
||||||
|
OS << "};\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
// Main Output.
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
// run - Emit the main instruction description records for the target...
|
// run - Emit the main instruction description records for the target...
|
||||||
void InstrInfoEmitter::run(std::ostream &OS) {
|
void InstrInfoEmitter::run(std::ostream &OS) {
|
||||||
@ -120,24 +172,10 @@ void InstrInfoEmitter::run(std::ostream &OS) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
std::map<std::vector<std::string>, unsigned> OperandInfosEmitted;
|
OperandInfoMapTy OperandInfoIDs;
|
||||||
unsigned OperandListNum = 0;
|
|
||||||
OperandInfosEmitted[std::vector<std::string>()] = ++OperandListNum;
|
|
||||||
|
|
||||||
// Emit all of the operand info records.
|
// Emit all of the operand info records.
|
||||||
OS << "\n";
|
EmitOperandInfo(OS, OperandInfoIDs);
|
||||||
for (CodeGenTarget::inst_iterator II = Target.inst_begin(),
|
|
||||||
E = Target.inst_end(); II != E; ++II) {
|
|
||||||
std::vector<std::string> OperandInfo = GetOperandInfo(II->second);
|
|
||||||
unsigned &N = OperandInfosEmitted[OperandInfo];
|
|
||||||
if (N == 0) {
|
|
||||||
N = ++OperandListNum;
|
|
||||||
OS << "static const TargetOperandInfo OperandInfo" << N << "[] = { ";
|
|
||||||
for (unsigned i = 0, e = OperandInfo.size(); i != e; ++i)
|
|
||||||
OS << "{ " << OperandInfo[i] << " }, ";
|
|
||||||
OS << "};\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Emit all of the TargetInstrDescriptor records in their ENUM ordering.
|
// Emit all of the TargetInstrDescriptor records in their ENUM ordering.
|
||||||
//
|
//
|
||||||
@ -148,7 +186,7 @@ void InstrInfoEmitter::run(std::ostream &OS) {
|
|||||||
|
|
||||||
for (unsigned i = 0, e = NumberedInstructions.size(); i != e; ++i)
|
for (unsigned i = 0, e = NumberedInstructions.size(); i != e; ++i)
|
||||||
emitRecord(*NumberedInstructions[i], i, InstrInfo, EmittedLists,
|
emitRecord(*NumberedInstructions[i], i, InstrInfo, EmittedLists,
|
||||||
OperandInfosEmitted, OS);
|
OperandInfoIDs, OS);
|
||||||
OS << "};\n";
|
OS << "};\n";
|
||||||
OS << "} // End llvm namespace \n";
|
OS << "} // End llvm namespace \n";
|
||||||
}
|
}
|
||||||
@ -156,7 +194,7 @@ void InstrInfoEmitter::run(std::ostream &OS) {
|
|||||||
void InstrInfoEmitter::emitRecord(const CodeGenInstruction &Inst, unsigned Num,
|
void InstrInfoEmitter::emitRecord(const CodeGenInstruction &Inst, unsigned Num,
|
||||||
Record *InstrInfo,
|
Record *InstrInfo,
|
||||||
std::map<std::vector<Record*>, unsigned> &EmittedLists,
|
std::map<std::vector<Record*>, unsigned> &EmittedLists,
|
||||||
std::map<std::vector<std::string>, unsigned> &OpInfo,
|
const OperandInfoMapTy &OpInfo,
|
||||||
std::ostream &OS) {
|
std::ostream &OS) {
|
||||||
int MinOperands;
|
int MinOperands;
|
||||||
if (!Inst.OperandList.empty())
|
if (!Inst.OperandList.empty())
|
||||||
@ -250,29 +288,11 @@ void InstrInfoEmitter::emitRecord(const CodeGenInstruction &Inst, unsigned Num,
|
|||||||
if (OperandInfo.empty())
|
if (OperandInfo.empty())
|
||||||
OS << "0";
|
OS << "0";
|
||||||
else
|
else
|
||||||
OS << "OperandInfo" << OpInfo[OperandInfo];
|
OS << "OperandInfo" << OpInfo.find(OperandInfo)->second;
|
||||||
|
|
||||||
OS << " }, // Inst #" << Num << " = " << Inst.TheDef->getName() << "\n";
|
OS << " }, // Inst #" << Num << " = " << Inst.TheDef->getName() << "\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
struct RecordNameComparator {
|
|
||||||
bool operator()(const Record *Rec1, const Record *Rec2) const {
|
|
||||||
return Rec1->getName() < Rec2->getName();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
void InstrInfoEmitter::GatherItinClasses() {
|
|
||||||
std::vector<Record*> DefList =
|
|
||||||
Records.getAllDerivedDefinitions("InstrItinClass");
|
|
||||||
std::sort(DefList.begin(), DefList.end(), RecordNameComparator());
|
|
||||||
|
|
||||||
for (unsigned i = 0, N = DefList.size(); i < N; i++)
|
|
||||||
ItinClassMap[DefList[i]->getName()] = i;
|
|
||||||
}
|
|
||||||
|
|
||||||
unsigned InstrInfoEmitter::getItinClassNumber(const Record *InstRec) {
|
|
||||||
return ItinClassMap[InstRec->getValueAsDef("Itinerary")->getName()];
|
|
||||||
}
|
|
||||||
|
|
||||||
void InstrInfoEmitter::emitShiftedValue(Record *R, StringInit *Val,
|
void InstrInfoEmitter::emitShiftedValue(Record *R, StringInit *Val,
|
||||||
IntInit *ShiftInt, std::ostream &OS) {
|
IntInit *ShiftInt, std::ostream &OS) {
|
||||||
|
@ -39,18 +39,24 @@ public:
|
|||||||
void run(std::ostream &OS);
|
void run(std::ostream &OS);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
typedef std::map<std::vector<std::string>, unsigned> OperandInfoMapTy;
|
||||||
|
|
||||||
void printDefList(const std::vector<Record*> &Uses, unsigned Num,
|
void printDefList(const std::vector<Record*> &Uses, unsigned Num,
|
||||||
std::ostream &OS) const;
|
std::ostream &OS) const;
|
||||||
void emitRecord(const CodeGenInstruction &Inst, unsigned Num,
|
void emitRecord(const CodeGenInstruction &Inst, unsigned Num,
|
||||||
Record *InstrInfo,
|
Record *InstrInfo,
|
||||||
std::map<std::vector<Record*>, unsigned> &EL,
|
std::map<std::vector<Record*>, unsigned> &EL,
|
||||||
std::map<std::vector<std::string>, unsigned> &OpInfo,
|
const OperandInfoMapTy &OpInfo,
|
||||||
std::ostream &OS);
|
std::ostream &OS);
|
||||||
|
|
||||||
void GatherItinClasses();
|
void GatherItinClasses();
|
||||||
unsigned getItinClassNumber(const Record *InstRec);
|
unsigned getItinClassNumber(const Record *InstRec);
|
||||||
|
|
||||||
|
void EmitOperandInfo(std::ostream &OS, OperandInfoMapTy &OperandInfoIDs);
|
||||||
|
std::vector<std::string> GetOperandInfo(const CodeGenInstruction &Inst);
|
||||||
|
|
||||||
void emitShiftedValue(Record *R, StringInit *Val, IntInit *Shift,
|
void emitShiftedValue(Record *R, StringInit *Val, IntInit *Shift,
|
||||||
std::ostream &OS);
|
std::ostream &OS);
|
||||||
std::vector<std::string> GetOperandInfo(const CodeGenInstruction &Inst);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
} // End llvm namespace
|
} // End llvm namespace
|
||||||
|
Loading…
x
Reference in New Issue
Block a user