libebl: ebl_object_note print 32bit annobin address ranges correctly
Commit Message
Annobin address ranges were always printed as if they were 64bit wide
because addr_size was set to twice the size. This was done because the
note description size should contain two addresses. Fix this by setting
the address size to just one address and then check that descsz is
twice that.
* libebl/eblobjnote.c (ebl_object_note): Set addr_size to one
ELF_T_ADDR. Check descsz equals two times addr_size.
Signed-off-by: Mark Wielaard <mark@klomp.org>
---
libebl/eblobjnote.c | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
Comments
Hi,
On Wed, 2024-02-21 at 21:59 +0100, Mark Wielaard wrote:
> Annobin address ranges were always printed as if they were 64bit wide
> because addr_size was set to twice the size. This was done because the
> note description size should contain two addresses. Fix this by setting
> the address size to just one address and then check that descsz is
> twice that.
>
> * libebl/eblobjnote.c (ebl_object_note): Set addr_size to one
> ELF_T_ADDR. Check descsz equals two times addr_size.
After a quick chat with Aaron on irc I pushed this.
Cheers,
Mark
@@ -155,8 +155,8 @@ ebl_object_note (Ebl *ebl, uint32_t namesz, const char *name, uint32_t type,
} addrs;
size_t addr_size = gelf_fsize (ebl->elf, ELF_T_ADDR,
- 2, EV_CURRENT);
- if (descsz != addr_size)
+ 1, EV_CURRENT);
+ if (descsz != addr_size * 2)
printf ("<unknown data>\n");
else
{