From: Nick Alcock Date: Tue, 30 Jul 2024 11:28:04 +0000 (+0100) Subject: libctf: fix ctf_archive_count return value on big-endian X-Git-Tag: gdb-16-branchpoint~1258 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=86fd34fde15021bb9157b7da55316c34f8c9fe1d;p=thirdparty%2Fbinutils-gdb.git libctf: fix ctf_archive_count return value on big-endian This failed to properly byteswap its return value. The ctf_archive format predates the idea of "just write natively and flip on open", and byteswaps all over the place. It's too easy to forget one. The next revision of the archive format (not versioned, so we just tweak the magic number instead) should be native-endianned like the dicts inside it are. libctf/ * ctf-archive.c (ctf_archive_count): Byteswap return value. --- diff --git a/libctf/ctf-archive.c b/libctf/ctf-archive.c index 0034bf0982a..b73999cacb5 100644 --- a/libctf/ctf-archive.c +++ b/libctf/ctf-archive.c @@ -785,7 +785,7 @@ ctf_archive_count (const ctf_archive_t *wrapper) if (!wrapper->ctfi_is_archive) return 1; - return wrapper->ctfi_archive->ctfa_ndicts; + return le64toh (wrapper->ctfi_archive->ctfa_ndicts); } /* Look up a symbol in an archive by name or index (if the name is set, a lookup