diff options
author | Chris Lattner <sabre@nondot.org> | 2004-01-18 22:35:34 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2004-01-18 22:35:34 +0000 |
commit | 241024381f245bd02ba0e3bda80f3690f84c11de (patch) | |
tree | 8b5e70e12f00c5ba1d6709da9496e46558d632af /lib/Bytecode/Reader/Reader.cpp | |
parent | 33522d4f2553afbcba69aab39da438782fb0505c (diff) |
Save another 30K from 176.gcc by encoding the compaction table a bit more
intelligently.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@10918 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Bytecode/Reader/Reader.cpp')
-rw-r--r-- | lib/Bytecode/Reader/Reader.cpp | 21 |
1 files changed, 17 insertions, 4 deletions
diff --git a/lib/Bytecode/Reader/Reader.cpp b/lib/Bytecode/Reader/Reader.cpp index 2067f22211..f4b620ed19 100644 --- a/lib/Bytecode/Reader/Reader.cpp +++ b/lib/Bytecode/Reader/Reader.cpp @@ -496,8 +496,22 @@ void BytecodeParser::ParseCompactionTable(const unsigned char *&Buf, const unsigned char *End) { while (Buf != End) { - unsigned NumEntries = read_vbr_uint(Buf, End); - unsigned Ty = read_vbr_uint(Buf, End); + unsigned NumEntries; + unsigned Ty; + + NumEntries = read_vbr_uint(Buf, End); + switch (NumEntries & 3) { + case 0: + case 1: + case 2: + Ty = NumEntries >> 2; + NumEntries &= 3; + break; + case 3: + NumEntries >>= 2; + Ty = read_vbr_uint(Buf, End); + break; + } if (Ty >= CompactionTable.size()) CompactionTable.resize(Ty+1); @@ -513,11 +527,10 @@ void BytecodeParser::ParseCompactionTable(const unsigned char *&Buf, CompactionTable.resize(NumEntries+Type::FirstDerivedTyID); } else { - assert(NumEntries != 0 && "Cannot read zero entries!"); const Type *Typ = getType(Ty); // Push the implicit zero CompactionTable[Ty].push_back(Constant::getNullValue(Typ)); - for (unsigned i = 1; i != NumEntries; ++i) { + for (unsigned i = 0; i != NumEntries; ++i) { Value *V = getGlobalTableValue(Typ, read_vbr_uint(Buf, End)); CompactionTable[Ty].push_back(V); } |