diff options
Diffstat (limited to 'linker/linker.cpp')
-rw-r--r-- | linker/linker.cpp | 29 |
1 files changed, 17 insertions, 12 deletions
diff --git a/linker/linker.cpp b/linker/linker.cpp index 8452cd41a..0e6fa450d 100644 --- a/linker/linker.cpp +++ b/linker/linker.cpp @@ -1780,14 +1780,8 @@ static ElfW(Addr) get_addend(ElfW(Rel)* rel, ElfW(Addr) reloc_addr) { #endif template<typename ElfRelIteratorT> -bool soinfo::relocate(ElfRelIteratorT&& rel_iterator, const soinfo_list_t& global_group, - const soinfo_list_t& local_group) { - VersionTracker version_tracker; - - if (!version_tracker.init(this)) { - return false; - } - +bool soinfo::relocate(const VersionTracker& version_tracker, ElfRelIteratorT&& rel_iterator, + const soinfo_list_t& global_group, const soinfo_list_t& local_group) { for (size_t idx = 0; rel_iterator.has_next(); ++idx) { const auto rel = rel_iterator.next(); if (rel == nullptr) { @@ -2866,6 +2860,12 @@ bool soinfo::link_image(const soinfo_list_t& global_group, const soinfo_list_t& local_group_root_ = this; } + VersionTracker version_tracker; + + if (!version_tracker.init(this)) { + return false; + } + #if !defined(__LP64__) if (has_text_relocations) { // Make segments writable to allow text relocations to work properly. We will later call @@ -2894,6 +2894,7 @@ bool soinfo::link_image(const soinfo_list_t& global_group, const soinfo_list_t& const size_t packed_relocs_size = android_relocs_size_ - 4; relocated = relocate( + version_tracker, packed_reloc_iterator<sleb128_decoder>( sleb128_decoder(packed_relocs, packed_relocs_size)), global_group, local_group); @@ -2910,26 +2911,30 @@ bool soinfo::link_image(const soinfo_list_t& global_group, const soinfo_list_t& #if defined(USE_RELA) if (rela_ != nullptr) { DEBUG("[ relocating %s ]", get_soname()); - if (!relocate(plain_reloc_iterator(rela_, rela_count_), global_group, local_group)) { + if (!relocate(version_tracker, + plain_reloc_iterator(rela_, rela_count_), global_group, local_group)) { return false; } } if (plt_rela_ != nullptr) { DEBUG("[ relocating %s plt ]", get_soname()); - if (!relocate(plain_reloc_iterator(plt_rela_, plt_rela_count_), global_group, local_group)) { + if (!relocate(version_tracker, + plain_reloc_iterator(plt_rela_, plt_rela_count_), global_group, local_group)) { return false; } } #else if (rel_ != nullptr) { DEBUG("[ relocating %s ]", get_soname()); - if (!relocate(plain_reloc_iterator(rel_, rel_count_), global_group, local_group)) { + if (!relocate(version_tracker, + plain_reloc_iterator(rel_, rel_count_), global_group, local_group)) { return false; } } if (plt_rel_ != nullptr) { DEBUG("[ relocating %s plt ]", get_soname()); - if (!relocate(plain_reloc_iterator(plt_rel_, plt_rel_count_), global_group, local_group)) { + if (!relocate(version_tracker, + plain_reloc_iterator(plt_rel_, plt_rel_count_), global_group, local_group)) { return false; } } |