From: Jens Remus Date: Fri, 11 Jul 2025 08:29:40 +0000 (+0200) Subject: sframe: Ignore section padding when converting endianness X-Git-Tag: binutils-2_45~99 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=b36a8e57eaa45df0d57cbc87db6734beed074ccc;p=thirdparty%2Fbinutils-gdb.git sframe: Ignore section padding when converting endianness The .sframe section may have a trailing padding due to the architecture- specific default section alignment. Do not treat this padding as error when converting between target and host endianness. This can be observed when building Binutils with SFrame s390x support on x86-64 for s390x using configure option "--target=s390x-ibm-linux-gnu" and running the GAS test suite. While at it reuse the determined SFrame section header size. libsframe/ * sframe.c (flip_sframe): Ignore .sframe section padding. Reuse SFrame header size. Reported-by: Indu Bhagat Signed-off-by: Jens Remus --- diff --git a/libsframe/sframe.c b/libsframe/sframe.c index ea0e1c7cd23..977abf5ef0a 100644 --- a/libsframe/sframe.c +++ b/libsframe/sframe.c @@ -520,7 +520,7 @@ flip_sframe (char *frame_buf, size_t buf_size, uint32_t to_foreign) fre_offset = fdep->sfde_func_start_fre_off; } - fp = frame_buf + sframe_get_hdr_size (ihp) + ihp->sfh_freoff; + fp = frame_buf + hdrsz + ihp->sfh_freoff; fp += fre_offset; for (; j < prev_frep_index + num_fres; j++) { @@ -535,8 +535,12 @@ flip_sframe (char *frame_buf, size_t buf_size, uint32_t to_foreign) prev_frep_index = j; } /* All FDEs and FREs must have been endian flipped by now. */ - if ((j != ihp->sfh_num_fres) || (bytes_flipped != (buf_size - hdrsz))) + if ((j != ihp->sfh_num_fres) || (bytes_flipped > (buf_size - hdrsz))) goto bad; + /* Optional trailing section padding. */ + for (fp = frame_buf + hdrsz + bytes_flipped; fp < frame_buf + buf_size; fp++) + if (*fp != '\0') + goto bad; /* Success. */ return 0;