forked from OSchip/llvm-project
c++11: Tidy up tblgen w/ range loops.
IntrInfoEmitter cleanup. llvm-svn: 206553
This commit is contained in:
parent
af81445411
commit
5198f3e988
|
@ -88,7 +88,7 @@ std::vector<std::string>
|
|||
InstrInfoEmitter::GetOperandInfo(const CodeGenInstruction &Inst) {
|
||||
std::vector<std::string> Result;
|
||||
|
||||
for (unsigned i = 0, e = Inst.Operands.size(); i != e; ++i) {
|
||||
for (auto &Op : Inst.Operands) {
|
||||
// Handle aggregate operands and normal operands the same way by expanding
|
||||
// either case into a list of operands for this op.
|
||||
std::vector<CGIOperandList::OperandInfo> OperandList;
|
||||
|
@ -97,14 +97,14 @@ InstrInfoEmitter::GetOperandInfo(const CodeGenInstruction &Inst) {
|
|||
// registers in their multi-operand operands. It may also be an anonymous
|
||||
// operand, which has a single operand, but no declared class for the
|
||||
// operand.
|
||||
DagInit *MIOI = Inst.Operands[i].MIOperandInfo;
|
||||
DagInit *MIOI = Op.MIOperandInfo;
|
||||
|
||||
if (!MIOI || MIOI->getNumArgs() == 0) {
|
||||
// Single, anonymous, operand.
|
||||
OperandList.push_back(Inst.Operands[i]);
|
||||
OperandList.push_back(Op);
|
||||
} else {
|
||||
for (unsigned j = 0, e = Inst.Operands[i].MINumOperands; j != e; ++j) {
|
||||
OperandList.push_back(Inst.Operands[i]);
|
||||
for (unsigned j = 0, e = Op.MINumOperands; j != e; ++j) {
|
||||
OperandList.push_back(Op);
|
||||
|
||||
Record *OpR = cast<DefInit>(MIOI->getArg(j))->getDef();
|
||||
OperandList.back().Rec = OpR;
|
||||
|
@ -134,24 +134,24 @@ InstrInfoEmitter::GetOperandInfo(const CodeGenInstruction &Inst) {
|
|||
|
||||
// Predicate operands. Check to see if the original unexpanded operand
|
||||
// was of type PredicateOp.
|
||||
if (Inst.Operands[i].Rec->isSubClassOf("PredicateOp"))
|
||||
if (Op.Rec->isSubClassOf("PredicateOp"))
|
||||
Res += "|(1<<MCOI::Predicate)";
|
||||
|
||||
// Optional def operands. Check to see if the original unexpanded operand
|
||||
// was of type OptionalDefOperand.
|
||||
if (Inst.Operands[i].Rec->isSubClassOf("OptionalDefOperand"))
|
||||
if (Op.Rec->isSubClassOf("OptionalDefOperand"))
|
||||
Res += "|(1<<MCOI::OptionalDef)";
|
||||
|
||||
// Fill in operand type.
|
||||
Res += ", MCOI::";
|
||||
assert(!Inst.Operands[i].OperandType.empty() && "Invalid operand type.");
|
||||
Res += Inst.Operands[i].OperandType;
|
||||
assert(!Op.OperandType.empty() && "Invalid operand type.");
|
||||
Res += Op.OperandType;
|
||||
|
||||
// Fill in constraint info.
|
||||
Res += ", ";
|
||||
|
||||
const CGIOperandList::ConstraintInfo &Constraint =
|
||||
Inst.Operands[i].Constraints[j];
|
||||
Op.Constraints[j];
|
||||
if (Constraint.isNone())
|
||||
Res += "0";
|
||||
else if (Constraint.isEarlyClobber())
|
||||
|
@ -177,16 +177,15 @@ void InstrInfoEmitter::EmitOperandInfo(raw_ostream &OS,
|
|||
|
||||
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);
|
||||
for (const CodeGenInstruction *Inst : Target.instructions()) {
|
||||
std::vector<std::string> OperandInfo = GetOperandInfo(*Inst);
|
||||
unsigned &N = OperandInfoIDs[OperandInfo];
|
||||
if (N != 0) continue;
|
||||
|
||||
N = ++OperandListNum;
|
||||
OS << "static const MCOperandInfo OperandInfo" << N << "[] = { ";
|
||||
for (unsigned i = 0, e = OperandInfo.size(); i != e; ++i)
|
||||
OS << "{ " << OperandInfo[i] << " }, ";
|
||||
for (const std::string &Info : OperandInfo)
|
||||
OS << "{ " << Info << " }, ";
|
||||
OS << "};\n";
|
||||
}
|
||||
}
|
||||
|
@ -206,14 +205,11 @@ void InstrInfoEmitter::initOperandMapData(
|
|||
OpNameMapTy &OperandMap) {
|
||||
|
||||
unsigned NumOperands = 0;
|
||||
for (unsigned i = 0, e = NumberedInstructions.size(); i != e; ++i) {
|
||||
const CodeGenInstruction *Inst = NumberedInstructions[i];
|
||||
if (!Inst->TheDef->getValueAsBit("UseNamedOperandTable")) {
|
||||
for (const CodeGenInstruction *Inst : NumberedInstructions) {
|
||||
if (!Inst->TheDef->getValueAsBit("UseNamedOperandTable"))
|
||||
continue;
|
||||
}
|
||||
std::map<unsigned, unsigned> OpList;
|
||||
for (unsigned j = 0, je = Inst->Operands.size(); j != je; ++j) {
|
||||
const CGIOperandList::OperandInfo &Info = Inst->Operands[j];
|
||||
for (const auto &Info : Inst->Operands) {
|
||||
StrUintMapIter I = Operands.find(Info.Name);
|
||||
|
||||
if (I == Operands.end()) {
|
||||
|
@ -256,8 +252,8 @@ void InstrInfoEmitter::emitOperandNameMappings(raw_ostream &OS,
|
|||
OS << "namespace " << Namespace << " {\n";
|
||||
OS << "namespace " << OpNameNS << " { \n";
|
||||
OS << "enum {\n";
|
||||
for (StrUintMapIter i = Operands.begin(), e = Operands.end(); i != e; ++i)
|
||||
OS << " " << i->first << " = " << i->second << ",\n";
|
||||
for (const auto &Op : Operands)
|
||||
OS << " " << Op.first << " = " << Op.second << ",\n";
|
||||
|
||||
OS << "OPERAND_LAST";
|
||||
OS << "\n};\n";
|
||||
|
@ -274,15 +270,13 @@ void InstrInfoEmitter::emitOperandNameMappings(raw_ostream &OS,
|
|||
if (!Operands.empty()) {
|
||||
OS << " static const int16_t OperandMap [][" << Operands.size()
|
||||
<< "] = {\n";
|
||||
for (OpNameMapTy::iterator i = OperandMap.begin(), e = OperandMap.end();
|
||||
i != e; ++i) {
|
||||
const std::map<unsigned, unsigned> &OpList = i->first;
|
||||
for (const auto &Entry : OperandMap) {
|
||||
const std::map<unsigned, unsigned> &OpList = Entry.first;
|
||||
OS << "{";
|
||||
|
||||
// Emit a row of the OperandMap table
|
||||
for (unsigned ii = 0, ie = Operands.size(); ii != ie; ++ii)
|
||||
OS << (OpList.count(ii) == 0 ? -1 : (int)OpList.find(ii)->second)
|
||||
<< ", ";
|
||||
for (unsigned i = 0, e = Operands.size(); i != e; ++i)
|
||||
OS << (OpList.count(i) == 0 ? -1 : (int)OpList.find(i)->second) << ", ";
|
||||
|
||||
OS << "},\n";
|
||||
}
|
||||
|
@ -290,12 +284,9 @@ void InstrInfoEmitter::emitOperandNameMappings(raw_ostream &OS,
|
|||
|
||||
OS << " switch(Opcode) {\n";
|
||||
unsigned TableIndex = 0;
|
||||
for (OpNameMapTy::iterator i = OperandMap.begin(), e = OperandMap.end();
|
||||
i != e; ++i) {
|
||||
std::vector<std::string> &OpcodeList = i->second;
|
||||
|
||||
for (unsigned ii = 0, ie = OpcodeList.size(); ii != ie; ++ii)
|
||||
OS << " case " << OpcodeList[ii] << ":\n";
|
||||
for (const auto &Entry : OperandMap) {
|
||||
for (const std::string &Name : Entry.second)
|
||||
OS << " case " << Name << ":\n";
|
||||
|
||||
OS << " return OperandMap[" << TableIndex++ << "][NamedIdx];\n";
|
||||
}
|
||||
|
@ -328,9 +319,11 @@ void InstrInfoEmitter::emitOperandTypesEnum(raw_ostream &OS,
|
|||
OS << "namespace OpTypes { \n";
|
||||
OS << "enum OperandType {\n";
|
||||
|
||||
for (unsigned oi = 0, oe = Operands.size(); oi != oe; ++oi) {
|
||||
if (!Operands[oi]->isAnonymous())
|
||||
OS << " " << Operands[oi]->getName() << " = " << oi << ",\n";
|
||||
unsigned EnumVal = 0;
|
||||
for (const Record *Op : Operands) {
|
||||
if (!Op->isAnonymous())
|
||||
OS << " " << Op->getName() << " = " << EnumVal << ",\n";
|
||||
++EnumVal;
|
||||
}
|
||||
|
||||
OS << " OPERAND_TYPE_LIST_END" << "\n};\n";
|
||||
|
@ -365,9 +358,8 @@ void InstrInfoEmitter::run(raw_ostream &OS) {
|
|||
unsigned ListNumber = 0;
|
||||
|
||||
// Emit all of the instruction's implicit uses and defs.
|
||||
for (CodeGenTarget::inst_iterator II = Target.inst_begin(),
|
||||
E = Target.inst_end(); II != E; ++II) {
|
||||
Record *Inst = (*II)->TheDef;
|
||||
for (const CodeGenInstruction *II : Target.instructions()) {
|
||||
Record *Inst = II->TheDef;
|
||||
std::vector<Record*> Uses = Inst->getValueAsListOfDefs("Uses");
|
||||
if (!Uses.empty()) {
|
||||
unsigned &IL = EmittedLists[Uses];
|
||||
|
@ -391,29 +383,30 @@ void InstrInfoEmitter::run(raw_ostream &OS) {
|
|||
const std::vector<const CodeGenInstruction*> &NumberedInstructions =
|
||||
Target.getInstructionsByEnumValue();
|
||||
|
||||
for (unsigned i = 0, e = NumberedInstructions.size(); i != e; ++i)
|
||||
emitRecord(*NumberedInstructions[i], i, InstrInfo, EmittedLists,
|
||||
OperandInfoIDs, OS);
|
||||
SequenceToOffsetTable<std::string> InstrNames;
|
||||
unsigned Num = 0;
|
||||
for (const CodeGenInstruction *Inst : NumberedInstructions) {
|
||||
// Keep a list of the instruction names.
|
||||
InstrNames.add(Inst->TheDef->getName());
|
||||
// Emit the record into the table.
|
||||
emitRecord(*Inst, Num++, InstrInfo, EmittedLists, OperandInfoIDs, OS);
|
||||
}
|
||||
OS << "};\n\n";
|
||||
|
||||
// Build an array of instruction names
|
||||
SequenceToOffsetTable<std::string> InstrNames;
|
||||
for (unsigned i = 0, e = NumberedInstructions.size(); i != e; ++i) {
|
||||
const CodeGenInstruction *Instr = NumberedInstructions[i];
|
||||
InstrNames.add(Instr->TheDef->getName());
|
||||
}
|
||||
|
||||
// Emit the array of instruction names.
|
||||
InstrNames.layout();
|
||||
OS << "extern const char " << TargetName << "InstrNameData[] = {\n";
|
||||
InstrNames.emit(OS, printChar);
|
||||
OS << "};\n\n";
|
||||
|
||||
OS << "extern const unsigned " << TargetName <<"InstrNameIndices[] = {";
|
||||
for (unsigned i = 0, e = NumberedInstructions.size(); i != e; ++i) {
|
||||
if (i % 8 == 0)
|
||||
Num = 0;
|
||||
for (const CodeGenInstruction *Inst : NumberedInstructions) {
|
||||
// Newline every eight entries.
|
||||
if (Num % 8 == 0)
|
||||
OS << "\n ";
|
||||
const CodeGenInstruction *Instr = NumberedInstructions[i];
|
||||
OS << InstrNames.get(Instr->TheDef->getName()) << "U, ";
|
||||
OS << InstrNames.get(Inst->TheDef->getName()) << "U, ";
|
||||
++Num;
|
||||
}
|
||||
|
||||
OS << "\n};\n\n";
|
||||
|
@ -586,18 +579,16 @@ void InstrInfoEmitter::emitEnums(raw_ostream &OS) {
|
|||
|
||||
OS << "namespace " << Namespace << " {\n";
|
||||
OS << " enum {\n";
|
||||
for (unsigned i = 0, e = NumberedInstructions.size(); i != e; ++i) {
|
||||
OS << " " << NumberedInstructions[i]->TheDef->getName()
|
||||
<< "\t= " << i << ",\n";
|
||||
}
|
||||
unsigned Num = 0;
|
||||
for (const CodeGenInstruction *Inst : NumberedInstructions)
|
||||
OS << " " << Inst->TheDef->getName() << "\t= " << Num++ << ",\n";
|
||||
OS << " INSTRUCTION_LIST_END = " << NumberedInstructions.size() << "\n";
|
||||
OS << " };\n";
|
||||
OS << "namespace Sched {\n";
|
||||
OS << " enum {\n";
|
||||
for (unsigned i = 0, e = SchedModels.numInstrSchedClasses(); i != e; ++i) {
|
||||
OS << " " << SchedModels.getSchedClass(i).Name
|
||||
<< "\t= " << i << ",\n";
|
||||
}
|
||||
Num = 0;
|
||||
for (const auto &Class : SchedModels.explicit_classes())
|
||||
OS << " " << Class.Name << "\t= " << Num++ << ",\n";
|
||||
OS << " SCHED_LIST_END = " << SchedModels.numInstrSchedClasses() << "\n";
|
||||
OS << " };\n}\n}\n";
|
||||
OS << "} // End llvm namespace \n";
|
||||
|
|
Loading…
Reference in New Issue