mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-29 10:25:12 +00:00
Reduce malloc traffic in DwarfAccelTable
- Don't copy offsets into HashData, the underlying vector won't change once the table is finalized. - Allocate HashData and HashDataContents in a BumpPtrAllocator. - Allocate string map entries in the same allocator. - Random cleanups. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@154694 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -36,35 +36,20 @@ const char *DwarfAccelTable::Atom::AtomTypeString(enum AtomType AT) {
|
||||
llvm_unreachable("invalid AtomType!");
|
||||
}
|
||||
|
||||
// The general case would need to have a less hard coded size for the
|
||||
// length of the HeaderData, however, if we're constructing based on a
|
||||
// single Atom then we know it will always be: 4 + 4 + 2 + 2.
|
||||
DwarfAccelTable::DwarfAccelTable(DwarfAccelTable::Atom atom) :
|
||||
Header(12),
|
||||
HeaderData(atom) {
|
||||
}
|
||||
|
||||
// The length of the header data is always going to be 4 + 4 + 4*NumAtoms.
|
||||
DwarfAccelTable::DwarfAccelTable(std::vector<DwarfAccelTable::Atom> &atomList) :
|
||||
DwarfAccelTable::DwarfAccelTable(ArrayRef<DwarfAccelTable::Atom> atomList) :
|
||||
Header(8 + (atomList.size() * 4)),
|
||||
HeaderData(atomList) {
|
||||
}
|
||||
HeaderData(atomList),
|
||||
Entries(Allocator) { }
|
||||
|
||||
DwarfAccelTable::~DwarfAccelTable() {
|
||||
for (size_t i = 0, e = Data.size(); i < e; ++i)
|
||||
delete Data[i];
|
||||
for (StringMap<DataArray>::iterator
|
||||
EI = Entries.begin(), EE = Entries.end(); EI != EE; ++EI)
|
||||
for (DataArray::iterator DI = EI->second.begin(),
|
||||
DE = EI->second.end(); DI != DE; ++DI)
|
||||
delete (*DI);
|
||||
}
|
||||
DwarfAccelTable::~DwarfAccelTable() { }
|
||||
|
||||
void DwarfAccelTable::AddName(StringRef Name, DIE* die, char Flags) {
|
||||
assert(Data.empty() && "Already finalized!");
|
||||
// If the string is in the list already then add this die to the list
|
||||
// otherwise add a new one.
|
||||
DataArray &DIEs = Entries[Name];
|
||||
DIEs.push_back(new HashDataContents(die, Flags));
|
||||
DIEs.push_back(new (Allocator) HashDataContents(die, Flags));
|
||||
}
|
||||
|
||||
void DwarfAccelTable::ComputeBucketCount(void) {
|
||||
@@ -85,31 +70,23 @@ void DwarfAccelTable::ComputeBucketCount(void) {
|
||||
Header.hashes_count = num;
|
||||
}
|
||||
|
||||
namespace {
|
||||
// DIESorter - comparison predicate that sorts DIEs by their offset.
|
||||
struct DIESorter {
|
||||
bool operator()(const struct DwarfAccelTable::HashDataContents *A,
|
||||
const struct DwarfAccelTable::HashDataContents *B) const {
|
||||
return A->Die->getOffset() < B->Die->getOffset();
|
||||
}
|
||||
};
|
||||
// compareDIEs - comparison predicate that sorts DIEs by their offset.
|
||||
static bool compareDIEs(const DwarfAccelTable::HashDataContents *A,
|
||||
const DwarfAccelTable::HashDataContents *B) {
|
||||
return A->Die->getOffset() < B->Die->getOffset();
|
||||
}
|
||||
|
||||
void DwarfAccelTable::FinalizeTable(AsmPrinter *Asm, const char *Prefix) {
|
||||
// Create the individual hash data outputs.
|
||||
for (StringMap<DataArray>::iterator
|
||||
EI = Entries.begin(), EE = Entries.end(); EI != EE; ++EI) {
|
||||
struct HashData *Entry = new HashData((*EI).getKeyData());
|
||||
|
||||
// Unique the entries.
|
||||
std::stable_sort(EI->second.begin(), EI->second.end(), DIESorter());
|
||||
std::stable_sort(EI->second.begin(), EI->second.end(), compareDIEs);
|
||||
EI->second.erase(std::unique(EI->second.begin(), EI->second.end()),
|
||||
EI->second.end());
|
||||
|
||||
for (DataArray::const_iterator DI = EI->second.begin(),
|
||||
DE = EI->second.end();
|
||||
DI != DE; ++DI)
|
||||
Entry->addData((*DI));
|
||||
HashData *Entry = new (Allocator) HashData(EI->getKey(), EI->second);
|
||||
Data.push_back(Entry);
|
||||
}
|
||||
|
||||
@@ -216,7 +193,7 @@ void DwarfAccelTable::EmitData(AsmPrinter *Asm, DwarfDebug *D) {
|
||||
D->getStringPool());
|
||||
Asm->OutStreamer.AddComment("Num DIEs");
|
||||
Asm->EmitInt32((*HI)->Data.size());
|
||||
for (std::vector<struct HashDataContents*>::const_iterator
|
||||
for (ArrayRef<HashDataContents*>::const_iterator
|
||||
DI = (*HI)->Data.begin(), DE = (*HI)->Data.end();
|
||||
DI != DE; ++DI) {
|
||||
// Emit the DIE offset
|
||||
|
Reference in New Issue
Block a user