DwarfAccelTable: remove unneeded bucket terminators.

Last commit fixed the handling of hash collisions, but it introdcuced
unneeded bucket terminators in some places. The generated table was
correct, it can just be a tiny bit smaller. As the previous table was
correct, the test doesn't need updating. If we really wanted to test
this, I could add the section size to the dwarf dump and test for a
precise value there. IMO the correctness test is sufficient.

llvm-svn: 231748
This commit is contained in:
Frederic Riss 2015-03-10 03:47:55 +00:00
parent c6012545fa
commit 44a219f0a0
1 changed files with 3 additions and 2 deletions

View File

@ -205,8 +205,8 @@ void DwarfAccelTable::EmitOffsets(AsmPrinter *Asm, MCSymbol *SecBegin) {
// Terminate each HashData bucket with 0. // Terminate each HashData bucket with 0.
void DwarfAccelTable::EmitData(AsmPrinter *Asm, DwarfDebug *D, void DwarfAccelTable::EmitData(AsmPrinter *Asm, DwarfDebug *D,
MCSymbol *StrSym) { MCSymbol *StrSym) {
uint64_t PrevHash = UINT64_MAX;
for (size_t i = 0, e = Buckets.size(); i < e; ++i) { for (size_t i = 0, e = Buckets.size(); i < e; ++i) {
uint64_t PrevHash = UINT64_MAX;
for (HashList::const_iterator HI = Buckets[i].begin(), for (HashList::const_iterator HI = Buckets[i].begin(),
HE = Buckets[i].end(); HE = Buckets[i].end();
HI != HE; ++HI) { HI != HE; ++HI) {
@ -235,6 +235,7 @@ void DwarfAccelTable::EmitData(AsmPrinter *Asm, DwarfDebug *D,
PrevHash = (*HI)->HashValue; PrevHash = (*HI)->HashValue;
} }
// Emit the final end marker for the bucket. // Emit the final end marker for the bucket.
if (!Buckets[i].empty())
Asm->EmitInt32(0); Asm->EmitInt32(0);
} }
} }