1be8b22f48
When building iputils for powerpc with BR2_PIC_PIE enabled, the arping/rdisc/tftpd binaries will segfault at runtime. This can be traced back to a few bugs in patchelf corrupting the ELFs when resizing the RPATH to replace "$ORIGIN/" with "/usr/sbin". This patch pulls in upstream fixes to prevent the binaries from being needlessly inflated, prevent the startPage from always being adjusted, fix a few minor bugs, and fix incorrect endianness handling. Signed-off-by: Conrad Ratschan <conrad.ratschan@rockwellcollins.com> Signed-off-by: Thomas Petazzoni <thomas.petazzoni@bootlin.com>
56 lines
2.0 KiB
Diff
56 lines
2.0 KiB
Diff
From 5df4791bf077127684faceeeea8bfab063e43774 Mon Sep 17 00:00:00 2001
|
|
From: Richard Purdie <richard.purdie@linuxfoundation.org>
|
|
Date: Wed, 3 Jun 2020 12:14:58 +0100
|
|
Subject: [PATCH] Fix shared library corruption when rerunning patchelf
|
|
|
|
When running patchelf on some existing patchelf'd binaries to change to longer
|
|
RPATHS, ldd would report the binaries as invalid. The output of objdump -x on
|
|
those libraryies should show the top of the .dynamic section is getting trashed,
|
|
something like:
|
|
|
|
0x600000001 0x0000000000429000
|
|
0x335000 0x0000000000335000
|
|
0xc740 0x000000000000c740
|
|
0x1000 0x0000000000009098
|
|
SONAME libglib-2.0.so.0
|
|
|
|
(which should be RPATH and DT_NEEDED entries)
|
|
|
|
This was tracked down to the code which injects the PT_LOAD section.
|
|
|
|
The issue is that if the program headers were previously relocated to the end
|
|
of the file which was how patchelf operated previously, the relocation code
|
|
wouldn't work properly on a second run as it now assumes they're located after
|
|
the elf header. This change forces them back to immediately follow the elf
|
|
header which is where the code has made space for them.
|
|
|
|
Should fix https://github.com/NixOS/patchelf/issues/170
|
|
and https://github.com/NixOS/patchelf/issues/192
|
|
|
|
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
|
|
|
|
Fetch from: https://github.com/NixOS/patchelf/commit/ad5f1f078b716802dfb8f7226cb1d5c720348a78
|
|
|
|
Backported to v0.9
|
|
|
|
Signed-off-by: Conrad Ratschan <conrad.ratschan@rockwellcollins.com>
|
|
---
|
|
src/patchelf.cc | 1 +
|
|
1 file changed, 1 insertion(+)
|
|
|
|
diff --git a/src/patchelf.cc b/src/patchelf.cc
|
|
index c2147af..1224a89 100644
|
|
--- a/src/patchelf.cc
|
|
+++ b/src/patchelf.cc
|
|
@@ -706,6 +706,7 @@ void ElfFile<ElfFileParamNames>::rewriteSectionsLibrary()
|
|
|
|
|
|
/* Add a segment that maps the replaced sections into memory. */
|
|
+ wri(hdr->e_phoff, sizeof(Elf_Ehdr));
|
|
phdrs.resize(rdi(hdr->e_phnum) + 1);
|
|
wri(hdr->e_phnum, rdi(hdr->e_phnum) + 1);
|
|
Elf_Phdr & phdr = phdrs[rdi(hdr->e_phnum) - 1];
|
|
--
|
|
2.17.1
|
|
|