diff options
author | Jakob Stoklund Olesen <stoklund@2pi.dk> | 2011-06-15 04:50:36 +0000 |
---|---|---|
committer | Jakob Stoklund Olesen <stoklund@2pi.dk> | 2011-06-15 04:50:36 +0000 |
commit | ae1920b1efa72c1789d562df4746110d0c2e10bd (patch) | |
tree | 22d7d8690b9997d57f32d4a0fd850b3d99dd0846 /utils/TableGen/InstrInfoEmitter.cpp | |
parent | 393c4047c05b6d7b5851d339e51bb2cc35f630c2 (diff) | |
download | llvm-ae1920b1efa72c1789d562df4746110d0c2e10bd.tar.gz llvm-ae1920b1efa72c1789d562df4746110d0c2e10bd.tar.bz2 llvm-ae1920b1efa72c1789d562df4746110d0c2e10bd.tar.xz |
Give CodeGenRegisterClass a real sorted member set.
Make the Elements vector private and expose an ArrayRef through
getOrder() instead. getOrder will eventually provide multiple
user-specified allocation orders.
Use the sorted member set for member and subclass tests. Clean up a lot
of ad hoc searches.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@133040 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils/TableGen/InstrInfoEmitter.cpp')
-rw-r--r-- | utils/TableGen/InstrInfoEmitter.cpp | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/utils/TableGen/InstrInfoEmitter.cpp b/utils/TableGen/InstrInfoEmitter.cpp index 67cce0e55f..fc544ee658 100644 --- a/utils/TableGen/InstrInfoEmitter.cpp +++ b/utils/TableGen/InstrInfoEmitter.cpp @@ -166,13 +166,13 @@ void InstrInfoEmitter::DetectRegisterClassBarriers(std::vector<Record*> &Defs, for (unsigned i = 0, e = RCs.size(); i != e; ++i) { const CodeGenRegisterClass &RC = RCs[i]; - unsigned NumRegs = RC.Elements.size(); - if (NumRegs > NumDefs) + ArrayRef<Record*> Order = RC.getOrder(); + if (Order.size() > NumDefs) continue; // Can't possibly clobber this RC. bool Clobber = true; - for (unsigned j = 0; j < NumRegs; ++j) { - Record *Reg = RC.Elements[j]; + for (unsigned j = 0; j < Order.size(); ++j) { + Record *Reg = Order[j]; if (!DefSet.count(Reg)) { Clobber = false; break; |