am db0785cb: Merge "Optimize symbol lookup"

* commit 'db0785cbf9ee6cc0ace5c89496d7e9f12c288a83':
  Optimize symbol lookup
This commit is contained in:
Dmitriy Ivanov 2014-08-13 16:33:27 +00:00 committed by Android Git Automerger
commit 15921382fb
2 changed files with 17 additions and 0 deletions

View File

@ -100,6 +100,15 @@ class LinkedList {
} }
} }
bool contains(const T* el) {
for (LinkedListEntry<T>* e = head_; e != nullptr; e = e->next) {
if (e->element != nullptr && e->element == el) {
return true;
}
}
return false;
}
private: private:
LinkedListEntry<T>* head_; LinkedListEntry<T>* head_;
LinkedListEntry<T>* tail_; LinkedListEntry<T>* tail_;

View File

@ -607,17 +607,24 @@ class SoinfoListAllocatorRW {
// specified soinfo object and its dependencies in breadth first order. // specified soinfo object and its dependencies in breadth first order.
ElfW(Sym)* dlsym_handle_lookup(soinfo* si, soinfo** found, const char* name, soinfo* caller) { ElfW(Sym)* dlsym_handle_lookup(soinfo* si, soinfo** found, const char* name, soinfo* caller) {
LinkedList<soinfo, SoinfoListAllocatorRW> visit_list; LinkedList<soinfo, SoinfoListAllocatorRW> visit_list;
LinkedList<soinfo, SoinfoListAllocatorRW> visited;
visit_list.push_back(si); visit_list.push_back(si);
soinfo* current_soinfo; soinfo* current_soinfo;
while ((current_soinfo = visit_list.pop_front()) != nullptr) { while ((current_soinfo = visit_list.pop_front()) != nullptr) {
if (visited.contains(current_soinfo)) {
continue;
}
ElfW(Sym)* result = soinfo_elf_lookup(current_soinfo, elfhash(name), name, ElfW(Sym)* result = soinfo_elf_lookup(current_soinfo, elfhash(name), name,
caller == current_soinfo ? SymbolLookupScope::kAllowLocal : SymbolLookupScope::kExcludeLocal); caller == current_soinfo ? SymbolLookupScope::kAllowLocal : SymbolLookupScope::kExcludeLocal);
if (result != nullptr) { if (result != nullptr) {
*found = current_soinfo; *found = current_soinfo;
visit_list.clear(); visit_list.clear();
visited.clear();
return result; return result;
} }
visited.push_back(current_soinfo);
current_soinfo->get_children().for_each([&](soinfo* child) { current_soinfo->get_children().for_each([&](soinfo* child) {
visit_list.push_back(child); visit_list.push_back(child);
@ -625,6 +632,7 @@ ElfW(Sym)* dlsym_handle_lookup(soinfo* si, soinfo** found, const char* name, soi
} }
visit_list.clear(); visit_list.clear();
visited.clear();
return nullptr; return nullptr;
} }