Date: Mon, 25 Dec 2006 02:22:23 +0000 (UTC) From: Joseph Koshy <jkoshy@FreeBSD.org> To: src-committers@FreeBSD.org, cvs-src@FreeBSD.org, cvs-all@FreeBSD.org Subject: cvs commit: src/lib/libelf Makefile Version.map _libelf.h elf_getphnum.3 elf_phnum.c elf_scn.c elf_shnum.c elf_shstrndx.c elf_update.c libelf_checksum.c libelf_ehdr.c libelf_extended.c libelf_phdr.c Message-ID: <200612250222.kBP2MNwE050275@repoman.freebsd.org>
next in thread | raw e-mail | index | archive | help
jkoshy 2006-12-25 02:22:23 UTC FreeBSD src repository Modified files: lib/libelf Makefile Version.map _libelf.h elf_scn.c elf_shnum.c elf_shstrndx.c elf_update.c libelf_checksum.c libelf_ehdr.c libelf_phdr.c Added files: lib/libelf elf_getphnum.3 elf_phnum.c libelf_extended.c Log: Keep shadow copies of the `e_shnum', `e_phnum' and `e_shstrndx' members of the ELF Executable Header inside the library-private `struct _Elf' descriptor and only update the underlying Elf{32,64}_Ehdr structure on an elf_update(3) call. These fields of the Ehdr structure are technically `out of bounds' for an application program per the ELF(3) API, but we've seen applications that initialize a new Ehdr structure using memcpy(), messing up the library's invariants. [1] Implement elf_getphnum() and handle ELF objects with more than 64K program header table entries. Reported by: jb [1] Revision Changes Path 1.5 +3 -0 src/lib/libelf/Makefile 1.2 +1 -0 src/lib/libelf/Version.map 1.2 +5 -3 src/lib/libelf/_libelf.h 1.1 +87 -0 src/lib/libelf/elf_getphnum.3 (new) 1.1 +53 -0 src/lib/libelf/elf_phnum.c (new) 1.2 +26 -42 src/lib/libelf/elf_scn.c 1.2 +7 -77 src/lib/libelf/elf_shnum.c 1.2 +7 -65 src/lib/libelf/elf_shstrndx.c 1.2 +11 -7 src/lib/libelf/elf_update.c 1.2 +1 -1 src/lib/libelf/libelf_checksum.c 1.2 +82 -3 src/lib/libelf/libelf_ehdr.c 1.1 +136 -0 src/lib/libelf/libelf_extended.c (new) 1.2 +13 -21 src/lib/libelf/libelf_phdr.c
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200612250222.kBP2MNwE050275>