forked from OSchip/llvm-project
Store just the SimpleValueType in the generated VT tables for each register class, eliminating static ctors.
llvm-svn: 150173
This commit is contained in:
parent
541687f4be
commit
c602b6ecaf
|
@ -36,7 +36,7 @@ class TargetRegisterClass {
|
|||
public:
|
||||
typedef const unsigned* iterator;
|
||||
typedef const unsigned* const_iterator;
|
||||
typedef const EVT* vt_iterator;
|
||||
typedef const MVT::SimpleValueType* vt_iterator;
|
||||
typedef const TargetRegisterClass* const * sc_iterator;
|
||||
private:
|
||||
virtual void anchor();
|
||||
|
@ -46,7 +46,8 @@ private:
|
|||
const sc_iterator SuperClasses;
|
||||
const sc_iterator SuperRegClasses;
|
||||
public:
|
||||
TargetRegisterClass(const MCRegisterClass *MC, const EVT *vts,
|
||||
TargetRegisterClass(const MCRegisterClass *MC,
|
||||
const MVT::SimpleValueType *vts,
|
||||
const unsigned *subcm,
|
||||
const TargetRegisterClass * const *supcs,
|
||||
const TargetRegisterClass * const *superregcs)
|
||||
|
@ -110,7 +111,7 @@ public:
|
|||
///
|
||||
bool hasType(EVT vt) const {
|
||||
for(int i = 0; VTs[i] != MVT::Other; ++i)
|
||||
if (VTs[i] == vt)
|
||||
if (EVT(VTs[i]) == vt)
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
|
|
|
@ -521,7 +521,7 @@ RegisterInfoEmitter::runTargetDesc(raw_ostream &OS, CodeGenTarget &Target,
|
|||
// Emit the register list now.
|
||||
OS << " // " << Name
|
||||
<< " Register Class Value Types...\n"
|
||||
<< " static const EVT " << Name
|
||||
<< " static const MVT::SimpleValueType " << Name
|
||||
<< "[] = {\n ";
|
||||
for (unsigned i = 0, e = RC.VTs.size(); i != e; ++i)
|
||||
OS << getEnumName(RC.VTs[i]) << ", ";
|
||||
|
|
Loading…
Reference in New Issue