diff options
author | Benjamin Kramer <benny.kra@googlemail.com> | 2011-07-23 02:49:37 +0000 |
---|---|---|
committer | Benjamin Kramer <benny.kra@googlemail.com> | 2011-07-23 02:49:37 +0000 |
commit | 73ee74c6a97f6bb5fad5fa6dfa4559ddcb9ca383 (patch) | |
tree | 4d098045afdae623eeb488e7bb5d8a0145783ff3 | |
parent | 279c20fde856149388c8b2a4b414a60e22aa1f04 (diff) | |
download | bcm5719-llvm-73ee74c6a97f6bb5fad5fa6dfa4559ddcb9ca383.tar.gz bcm5719-llvm-73ee74c6a97f6bb5fad5fa6dfa4559ddcb9ca383.zip |
We always bounds check the bit set, there is no need to emit zero bytes at the end.
llvm-svn: 135841
-rw-r--r-- | llvm/utils/TableGen/RegisterInfoEmitter.cpp | 23 |
1 files changed, 10 insertions, 13 deletions
diff --git a/llvm/utils/TableGen/RegisterInfoEmitter.cpp b/llvm/utils/TableGen/RegisterInfoEmitter.cpp index 8ec45d41f27..f56dcd5b8c5 100644 --- a/llvm/utils/TableGen/RegisterInfoEmitter.cpp +++ b/llvm/utils/TableGen/RegisterInfoEmitter.cpp @@ -206,23 +206,20 @@ RegisterInfoEmitter::EmitRegMapping(raw_ostream &OS, // Helper to emit a set of bits into a constant byte array. class BitVectorEmitter { BitVector Values; - unsigned Len; public: - BitVectorEmitter(unsigned L) : Len(L%8 ? ((L/8)+1)*8 : L) { - Values.resize(Len); + void add(unsigned v) { + if (v >= Values.size()) + Values.resize(((v/8)+1)*8); // Round up to the next byte. + Values[v] = true; } - void add(unsigned v) { Values[v] = true; } - void print(raw_ostream &OS) { - for (unsigned i = 0, e = Len / 8; i != e; ++i) { + for (unsigned i = 0, e = Values.size() / 8; i != e; ++i) { unsigned char out = 0; - for (unsigned ii = 0, ie = 8; ii != ie; ++ii) - if (Values[i * 8 + ii]) - out |= 1 << ii; - OS << "0x"; - OS.write_hex(out); - OS << ", "; + for (unsigned j = 0; j != 8; ++j) + if (Values[i * 8 + j]) + out |= 1 << j; + OS << format("0x%02x, ", out); } } }; @@ -349,7 +346,7 @@ RegisterInfoEmitter::runMCDesc(raw_ostream &OS, CodeGenTarget &Target, OS << " // " << Name << " Bit set.\n" << " static const unsigned char " << Name << "Bits[] = {\n "; - BitVectorEmitter BVE(Target.getRegBank().getRegisters().size()+1); + BitVectorEmitter BVE; for (unsigned i = 0, e = Order.size(); i != e; ++i) { Record *Reg = Order[i]; BVE.add(Target.getRegBank().getReg(Reg)->EnumValue); |