/bionic/linker/ |
linker_main.h | 52 soinfo* soinfo_alloc(android_namespace_t* ns, const char* name, 57 soinfo* start_with, 60 soinfo* soinfos[], 61 std::vector<soinfo*>* ld_preloads, 69 void solist_add_soinfo(soinfo* si); 70 bool solist_remove_soinfo(soinfo* si); 71 soinfo* solist_get_head(); 72 soinfo* solist_get_somain(); 73 soinfo* solist_get_vdso();
|
linker_cfi.h | 64 bool AddLibrary(soinfo* si); 72 bool MaybeInit(soinfo *new_si, soinfo *solist); 79 bool NotifyLibDl(soinfo *solist, uintptr_t p); 92 bool AfterLoad(soinfo* si, soinfo *solist); 95 void BeforeUnload(soinfo* si); 98 bool InitialLinkDone(soinfo *solist);
|
linker_common_types.h | 43 struct soinfo; 47 static LinkedListEntry<soinfo>* alloc(); 48 static void free(LinkedListEntry<soinfo>* entry); 65 typedef LinkedList<soinfo, SoinfoListAllocator> soinfo_list_t;
|
linker_soinfo.cpp | 45 bool find_verdef_version_index(const soinfo* si, const version_info* vi, ElfW(Versym)* versym); 49 soinfo::soinfo(android_namespace_t* ns, const char* realpath, function in class:soinfo 71 soinfo::~soinfo() { 75 void soinfo::set_dt_runpath(const char* path) { 94 const ElfW(Versym)* soinfo::get_versym(size_t n) const { 102 ElfW(Addr) soinfo::get_verneed_ptr() const { 110 size_t soinfo::get_verneed_cnt() const { 118 ElfW(Addr) soinfo::get_verdef_ptr() const [all...] |
linker.h | 74 bool init(const soinfo* si_from); 78 bool init_verneed(const soinfo* si_from); 79 bool init_verdef(const soinfo* si_from); 81 const char* ver_name, const soinfo* target_si); 88 bool soinfo_do_lookup(soinfo* si_from, const char* name, const version_info* vi, 89 soinfo** si_found_in, const soinfo_list_t& global_group, 102 soinfo* get_libdl_info(const char* linker_path, 103 const soinfo& linker_si, 106 soinfo* find_containing_library(const void* p);
|
linker_namespaces.cpp | 62 bool android_namespace_t::is_accessible(soinfo* s) { 63 auto is_accessible_ftor = [this] (soinfo* si) { 64 // This is workaround for apps hacking into soinfo list. 67 DL_WARN("Warning: invalid soinfo version for \"%s\" (assuming inaccessible)", 88 return !s->get_parents().visit([&](soinfo* si) { 102 soinfo_list().for_each([&](soinfo* si) { 122 soinfo_list().for_each([&](soinfo* si) {
|
linker_cfi.cpp | 133 static soinfo* find_libdl(soinfo* solist) { 134 for (soinfo* si = solist; si != nullptr; si = si->next) { 143 static uintptr_t soinfo_find_symbol(soinfo* si, const char* s) { 152 uintptr_t soinfo_find_cfi_check(soinfo* si) { 163 bool CFIShadowWriter::AddLibrary(soinfo* si) { 196 bool CFIShadowWriter::NotifyLibDl(soinfo* solist, uintptr_t p) { 197 soinfo* libdl = find_libdl(solist); 212 bool CFIShadowWriter::MaybeInit(soinfo* new_si, soinfo* solist) [all...] |
linker_globals.h | 68 struct soinfo; 73 extern std::unordered_map<uintptr_t, soinfo*> g_soinfo_handles_map;
|
linker_soinfo.h | 56 // registered with this soinfo. In such 60 // soinfo is executed and this flag is 62 #define FLAG_NEW_SOINFO 0x40000000 // new soinfo format 97 const soinfo* target_si; 100 // TODO(dimitry): remove reference from soinfo member functions to this class. 107 struct soinfo { struct 132 soinfo* next; 208 soinfo(android_namespace_t* ns, const char* name, const struct stat* file_stat, 210 ~soinfo(); 220 void add_child(soinfo* child) [all...] |
linker_globals.cpp | 41 std::unordered_map<uintptr_t, soinfo*> g_soinfo_handles_map;
|
linker_namespaces.h | 123 void add_soinfo(soinfo* si) { 133 void remove_soinfo(soinfo* si) { 134 soinfo_list_.remove_if([&](soinfo* candidate) { 145 // Returns true if si is accessible from this namespace. A soinfo 148 bool is_accessible(soinfo* si);
|
linker.cpp | 84 static LinkerTypeAllocator<soinfo> g_soinfo_allocator; 85 static LinkerTypeAllocator<LinkedListEntry<soinfo>> g_soinfo_links_allocator; 186 static bool is_greylisted(android_namespace_t* ns, const char* name, const soinfo* needed_by) { 257 static void notify_gdb_of_load(soinfo* info) { 276 static void notify_gdb_of_unload(soinfo* info) { 280 LinkedListEntry<soinfo>* SoinfoListAllocator::alloc() { 284 void SoinfoListAllocator::free(LinkedListEntry<soinfo>* entry) { 296 soinfo* soinfo_alloc(android_namespace_t* ns, const char* name, 303 TRACE("name %s: allocating soinfo for ns=%p", name, ns); 305 soinfo* si = new (g_soinfo_allocator.alloc()) soinfo(ns, name, file_stat [all...] |
linker_main.cpp | 64 static soinfo* solist; 65 static soinfo* sonext; 66 static soinfo* somain; // main process, always the one after libdl_info 67 static soinfo* vdso; // vdso if present 69 void solist_add_soinfo(soinfo* si) { 74 bool solist_remove_soinfo(soinfo* si) { 75 soinfo *prev = nullptr, *trav; 100 soinfo* solist_get_head() { 104 soinfo* solist_get_somain() { 108 soinfo* solist_get_vdso() [all...] |
linker_mips.cpp | 42 template bool soinfo::relocate<plain_reloc_iterator>(const VersionTracker& version_tracker, 47 template bool soinfo::relocate<packed_reloc_iterator<sleb128_decoder>>( 54 bool soinfo::relocate(const VersionTracker& version_tracker, 78 soinfo* lsi = nullptr; 135 bool soinfo::mips_relocate_got(const VersionTracker& version_tracker, 164 soinfo* lsi = nullptr; 242 bool soinfo::mips_check_and_adjust_fp_modes() { 246 // Find soinfo's optional .MIPS.abiflags segment
|
dlfcn.cpp | 302 static uint8_t __libdl_info_buf[sizeof(soinfo)] __attribute__((aligned(8))); 303 static soinfo* __libdl_info = nullptr; 306 soinfo* get_libdl_info(const char* linker_path, 307 const soinfo& linker_si, 312 __libdl_info = new (__libdl_info_buf) soinfo(&g_default_namespace, linker_path, nullptr, 0, 0);
|