From: H.J. Lu Date: Tue, 21 Dec 2021 20:35:47 +0000 (-0800) Subject: elf: Remove excessive p_align check on PT_LOAD segments [BZ #28688] X-Git-Tag: glibc-2.35~214 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=163f625cf9becbb82dfec63a29e566324129c0cd;p=thirdparty%2Fglibc.git elf: Remove excessive p_align check on PT_LOAD segments [BZ #28688] p_align does not have to be a multiple of the page size. Only PT_LOAD segment layout should be aligned to the page size. 1: Remove p_align check against the page size. 2. Use the page size, instead of p_align, to check PT_LOAD segment layout. Reviewed-by: Florian Weimer --- diff --git a/elf/dl-load.c b/elf/dl-load.c index 721593135e3..2a1443387f6 100644 --- a/elf/dl-load.c +++ b/elf/dl-load.c @@ -1133,16 +1133,11 @@ _dl_map_object_from_fd (const char *name, const char *origname, int fd, case PT_LOAD: /* A load command tells us to map in part of the file. We record the load commands and process them all later. */ - if (__glibc_unlikely ((ph->p_align & (GLRO(dl_pagesize) - 1)) != 0)) - { - errstring = N_("ELF load command alignment not page-aligned"); - goto lose; - } if (__glibc_unlikely (((ph->p_vaddr - ph->p_offset) - & (ph->p_align - 1)) != 0)) + & (GLRO(dl_pagesize) - 1)) != 0)) { errstring - = N_("ELF load command address/offset not properly aligned"); + = N_("ELF load command address/offset not page-aligned"); goto lose; }