Compare commits

...

2 Commits

Author SHA1 Message Date
Nicolas 854a70cc95 added support for addend for SHT_REL relocations (used for 32 bit x86) 2025-11-13 20:24:11 +01:00
Nicolas 2e865b0785 __contains__ for lists added with test 2025-11-13 20:23:16 +01:00
2 changed files with 31 additions and 8 deletions

View File

@ -265,6 +265,14 @@ class elf_list(Generic[_T]):
def __iter__(self) -> Iterator[_T]:
return iter(self._data)
def __contains__(self, item: Union[str, int, _T]) -> bool:
if isinstance(item, str):
return any(getattr(el, 'name', '') == item for el in self._data)
elif isinstance(item, int):
return 0 <= item < len(self._data)
else:
return item in self._data
def _compact_table(self) -> tuple[list[str], list[list[Union[str, int]]], list[str]]:
return [], [[]], []
@ -488,17 +496,25 @@ class elf_file:
ret: dict[str, int] = dict()
if self.bit_width == 32:
ret['r_offset'] = self.read_int(el_off, 4)
offset = self.read_int(el_off, 4)
r_info = self.read_int(el_off + 4, 4)
ret['r_info'] = r_info
ret['r_addend'] = self.read_int(el_off + 8, 4, True) if sh.type == 'SHT_RELA' else 0
yield elf_relocation(self, ret, r_info >> 8, r_info & 0xFF, sh['sh_info'], i)
symbol_index = r_info >> 8
relocation_type = r_info & 0xFF
ret['r_addend'] = self.read_int(el_off + 8, 4, True) \
if sh.type == 'SHT_RELA' else self.read_int(offset, 4, True)
elif self.bit_width == 64:
ret['r_offset'] = self.read_int(el_off, 8)
offset = self.read_int(el_off, 8)
r_info = self.read_int(el_off + 8, 8)
ret['r_info'] = r_info
ret['r_addend'] = self.read_int(el_off + 16, 8, True) if sh.type == 'SHT_RELA' else 0
yield elf_relocation(self, ret, r_info >> 32, r_info & 0xFFFFFFFF, sh['sh_info'], i)
symbol_index = r_info >> 32
relocation_type = r_info & 0xFFFFFFFF
ret['r_addend'] = self.read_int(el_off + 16, 8, True) \
if sh.type == 'SHT_RELA' else self.read_int(offset, 4, True)
else:
raise NotImplementedError(f"{self.bit_width} bit is not supported")
ret['r_offset'] = offset
ret['r_info'] = r_info
yield elf_relocation(self, ret, symbol_index, relocation_type, sh['sh_info'], i)
def read_bytes(self, offset: int, num_bytes: int) -> bytes:
"""Read bytes from ELF file.

View File

@ -38,6 +38,13 @@ def test_simple_c() -> None:
for reloc in elf.get_relocations():
assert known_name(reloc.type), f"Relocation type {reloc.type} for {elf.architecture} in {path} is unknown."
assert 'imageWidth' in elf.objects or 'read_float_ret' in elf.objects, path
assert 'leet456456456n4ghn4hf56n4f' not in elf.objects
assert 0 in elf.objects
assert 1000 not in elf.objects
assert elf.objects[0] in elf.symbols
assert elf.objects[0] not in elf.functions
if __name__ == '__main__':
test_simple_c()