diff options
author | Mark Wielaard <mark@klomp.org> | 2019-03-06 20:02:52 +0100 |
---|---|---|
committer | Mark Wielaard <mark@klomp.org> | 2019-03-06 20:02:52 +0100 |
commit | ff063240ac97302f289b12ac7dff655cdc0d5d70 (patch) | |
tree | 2097b997a2e71ffcf7be207d60c8bd8307ba0421 /libasm/asm_end.c | |
parent | 75e147d0ab85262d9bb2fff093db7ce67dbd4b62 (diff) | |
download | elfutils-ff063240ac97302f289b12ac7dff655cdc0d5d70.tar.gz |
libasm: Check return value of gelf_update_ehdr in asm_end.
In theory the gelf_update_ehdr call could fail. Immediately report an
error in that case.
Signed-off-by: Mark Wielaard <mark@klomp.org>
Diffstat (limited to 'libasm/asm_end.c')
-rw-r--r-- | libasm/asm_end.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/libasm/asm_end.c b/libasm/asm_end.c index 5aab8dfa..99e95017 100644 --- a/libasm/asm_end.c +++ b/libasm/asm_end.c @@ -460,7 +460,11 @@ binary_end (AsmCtx_t *ctx) else ehdr->e_shstrndx = elf_ndxscn (shstrscn); - gelf_update_ehdr (ctx->out.elf, ehdr); + if (unlikely (gelf_update_ehdr (ctx->out.elf, ehdr) == 0)) + { + __libasm_seterrno (ASM_E_LIBELF); + result = -1; + } /* Write out the ELF file. */ if (unlikely (elf_update (ctx->out.elf, ELF_C_WRITE_MMAP) < 0)) |