aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAleksei Vetrov <vvvvvv@google.com>2023-01-27 23:42:03 +0000
committerAleksei Vetrov <vvvvvv@google.com>2023-01-27 23:51:23 +0000
commit500c5b730574f3175d23f2939a02b9c0dd8340be (patch)
tree69a013ee4366f78ac2b990644f9aba4ac5b1d39f
parentedc8f44d4fe4b9bef34bb823f2fd295606b48082 (diff)
downloadlibabigail-500c5b730574f3175d23f2939a02b9c0dd8340be.tar.gz
symtab: fix getting CRC in relocatable modules
In ELF with ET_REL type symbol value holds not absolute but relative to section value. This patch applies adjustment to the address, used in CRC value extraction. * src/abg-elf-helpers.cc (get_crc_for_symbol): Rename crc_symbol_value to crc_symbol_address and adjust it for relocatable ELF types. Change-Id: Iff28e7eaf2a1c95630116ad5fdf83ea007aeeba5 Signed-off-by: Aleksei Vetrov <vvvvvv@google.com>
-rw-r--r--src/abg-elf-helpers.cc9
1 files changed, 5 insertions, 4 deletions
diff --git a/src/abg-elf-helpers.cc b/src/abg-elf-helpers.cc
index a1c5fb5d..8345d5d2 100644
--- a/src/abg-elf-helpers.cc
+++ b/src/abg-elf-helpers.cc
@@ -918,10 +918,11 @@ bool
get_crc_for_symbol(Elf* elf_handle, GElf_Sym* crc_symbol, uint32_t& crc_value)
{
size_t crc_section_index = crc_symbol->st_shndx;
- uint64_t crc_symbol_value = crc_symbol->st_value;
+ GElf_Addr crc_symbol_address =
+ maybe_adjust_et_rel_sym_addr_to_abs_addr(elf_handle, crc_symbol);
if (crc_section_index == SHN_ABS)
{
- crc_value = crc_symbol_value;
+ crc_value = crc_symbol_address;
return true;
}
@@ -938,10 +939,10 @@ get_crc_for_symbol(Elf* elf_handle, GElf_Sym* crc_symbol, uint32_t& crc_value)
if (kcrctab_data == NULL)
return false;
- if (crc_symbol_value < sheader->sh_addr)
+ if (crc_symbol_address < sheader->sh_addr)
return false;
- size_t offset = crc_symbol_value - sheader->sh_addr;
+ size_t offset = crc_symbol_address - sheader->sh_addr;
if (offset + sizeof(uint32_t) > kcrctab_data->d_size
|| offset + sizeof(uint32_t) > sheader->sh_size)
return false;