forked from OSchip/llvm-project
Avoid emitting empty arrays, they're not standard C++.
It's only by luck that we haven't produced any yet, and clang refuses to compile them. llvm-svn: 149546
This commit is contained in:
parent
e71ddf2fcb
commit
855662ad9a
|
@ -640,16 +640,21 @@ RegisterInfoEmitter::runTargetDesc(raw_ostream &OS, CodeGenTarget &Target,
|
||||||
<< "getRawAllocationOrder(const MachineFunction &MF) const {\n";
|
<< "getRawAllocationOrder(const MachineFunction &MF) const {\n";
|
||||||
for (unsigned oi = 1 , oe = RC.getNumOrders(); oi != oe; ++oi) {
|
for (unsigned oi = 1 , oe = RC.getNumOrders(); oi != oe; ++oi) {
|
||||||
ArrayRef<Record*> Elems = RC.getOrder(oi);
|
ArrayRef<Record*> Elems = RC.getOrder(oi);
|
||||||
|
if (!Elems.empty()) {
|
||||||
OS << " static const unsigned AltOrder" << oi << "[] = {";
|
OS << " static const unsigned AltOrder" << oi << "[] = {";
|
||||||
for (unsigned elem = 0; elem != Elems.size(); ++elem)
|
for (unsigned elem = 0; elem != Elems.size(); ++elem)
|
||||||
OS << (elem ? ", " : " ") << getQualifiedName(Elems[elem]);
|
OS << (elem ? ", " : " ") << getQualifiedName(Elems[elem]);
|
||||||
OS << " };\n";
|
OS << " };\n";
|
||||||
}
|
}
|
||||||
|
}
|
||||||
OS << " const MCRegisterClass &MCR = " << Target.getName()
|
OS << " const MCRegisterClass &MCR = " << Target.getName()
|
||||||
<< "MCRegisterClasses[" << RC.getQualifiedName() + "RegClassID];"
|
<< "MCRegisterClasses[" << RC.getQualifiedName() + "RegClassID];\n"
|
||||||
<< " static const ArrayRef<unsigned> Order[] = {\n"
|
<< " static const ArrayRef<unsigned> Order[] = {\n"
|
||||||
<< " makeArrayRef(MCR.begin(), MCR.getNumRegs()";
|
<< " makeArrayRef(MCR.begin(), MCR.getNumRegs()";
|
||||||
for (unsigned oi = 1, oe = RC.getNumOrders(); oi != oe; ++oi)
|
for (unsigned oi = 1, oe = RC.getNumOrders(); oi != oe; ++oi)
|
||||||
|
if (RC.getOrder(oi).empty())
|
||||||
|
OS << "),\n ArrayRef<unsigned>(";
|
||||||
|
else
|
||||||
OS << "),\n makeArrayRef(AltOrder" << oi;
|
OS << "),\n makeArrayRef(AltOrder" << oi;
|
||||||
OS << ")\n };\n const unsigned Select = " << RC.getName()
|
OS << ")\n };\n const unsigned Select = " << RC.getName()
|
||||||
<< "AltOrderSelect(MF);\n assert(Select < " << RC.getNumOrders()
|
<< "AltOrderSelect(MF);\n assert(Select < " << RC.getNumOrders()
|
||||||
|
|
Loading…
Reference in New Issue