summaryrefslogtreecommitdiff
path: root/src/libelfu/elfops/check.c
diff options
context:
space:
mode:
authornorly <ny-git@enpas.org>2013-06-27 02:06:41 +0100
committernorly <ny-git@enpas.org>2013-06-27 02:06:41 +0100
commit6004cb3888eaac4995025fdba5f71b7fd861d81a (patch)
tree0047f97f32803947189393eb66af573be1085645 /src/libelfu/elfops/check.c
parent10fcfe36c13a11b3d28b5fb2cd1e89dc239bb6d0 (diff)
Relax restrictions on NOBITS sections
Diffstat (limited to 'src/libelfu/elfops/check.c')
-rw-r--r--src/libelfu/elfops/check.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/src/libelfu/elfops/check.c b/src/libelfu/elfops/check.c
index 108964a..a5aeef3 100644
--- a/src/libelfu/elfops/check.c
+++ b/src/libelfu/elfops/check.c
@@ -182,7 +182,7 @@ int elfu_eCheck(Elf *e)
if (PHDR_CONTAINS_SCN_IN_MEMORY(&phdrs[j], &shdrs[i])) {
GElf_Off shoff = phdrs[j].p_offset + (shdrs[i].sh_addr - phdrs[j].p_vaddr);
- if (shdrs[i].sh_offset != shoff
+ if ((shdrs[i].sh_offset != shoff && shdrs[i].sh_type != SHT_NOBITS)
|| !PHDR_CONTAINS_SCN_IN_FILE(&phdrs[j], &shdrs[i])) {
ELFU_WARN("elfu_eCheck: SHDR %d and PHDR %d report conflicting file/memory regions.\n", i, j);
goto ERROR;