mailarchive of the ptxdist mailing list
 help / color / mirror / Atom feed
From: Marc Kleine-Budde <mkl@pengutronix.de>
To: ptxdist@pengutronix.de
Cc: Marc Kleine-Budde <mkl@pengutronix.de>
Subject: [ptxdist] [PATCH] host-patchelf: new package
Date: Tue,  7 May 2019 15:09:07 +0200	[thread overview]
Message-ID: <20190507130907.25114-1-mkl@pengutronix.de> (raw)

PatchELF is a simple utility for modifying existing ELF executables and
libraries. It comes handy when dealing with existing binary tools with strange
NEEDED or without RUNPATH in the ELF header.

Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
---
 .../0001-fix-adjusting-startPage.patch        | 35 +++++++++++++++++++
 patches/patchelf-0.10/series                  |  4 +++
 rules/host-patchelf.in                        | 15 ++++++++
 rules/host-patchelf.make                      | 34 ++++++++++++++++++
 4 files changed, 88 insertions(+)
 create mode 100644 patches/patchelf-0.10/0001-fix-adjusting-startPage.patch
 create mode 100644 patches/patchelf-0.10/series
 create mode 100644 rules/host-patchelf.in
 create mode 100644 rules/host-patchelf.make

diff --git a/patches/patchelf-0.10/0001-fix-adjusting-startPage.patch b/patches/patchelf-0.10/0001-fix-adjusting-startPage.patch
new file mode 100644
index 000000000000..fa92041850ff
--- /dev/null
+++ b/patches/patchelf-0.10/0001-fix-adjusting-startPage.patch
@@ -0,0 +1,35 @@
+From: Ed Bartosh <ed.bartosh@linux.intel.com>
+Date: Fri, 21 Jul 2017 12:33:53 +0300
+Subject: [PATCH] fix adjusting startPage
+
+startPage is adjusted unconditionally for all executables.
+This results in incorrect addresses assigned to INTERP and LOAD
+program headers, which breaks patched executable.
+
+Adjusting startPage variable only when startOffset > startPage
+should fix this.
+
+This change is related to the issue NixOS#10
+
+Signed-off-by: Ed Bartosh <ed.bartosh@linux.intel.com>
+---
+ src/patchelf.cc | 6 ++----
+ 1 file changed, 2 insertions(+), 4 deletions(-)
+
+diff --git a/src/patchelf.cc b/src/patchelf.cc
+index 0b4965adff83..12d6bf1dde01 100644
+--- a/src/patchelf.cc
++++ b/src/patchelf.cc
+@@ -742,10 +742,8 @@ void ElfFile<ElfFileParamNames>::rewriteSectionsLibrary()
+        since DYN executables tend to start at virtual address 0, so
+        rewriteSectionsExecutable() won't work because it doesn't have
+        any virtual address space to grow downwards into. */
+-    if (isExecutable) {
+-        if (startOffset >= startPage) {
+-            debug("shifting new PT_LOAD segment by %d bytes to work around a Linux kernel bug\n", startOffset - startPage);
+-        }
++    if (isExecutable && startOffset > startPage) {
++        debug("shifting new PT_LOAD segment by %d bytes to work around a Linux kernel bug\n", startOffset - startPage);
+         startPage = startOffset;
+     }
+ 
diff --git a/patches/patchelf-0.10/series b/patches/patchelf-0.10/series
new file mode 100644
index 000000000000..c2e125d669bd
--- /dev/null
+++ b/patches/patchelf-0.10/series
@@ -0,0 +1,4 @@
+# generated by git-ptx-patches
+#tag:base --start-number 1
+0001-fix-adjusting-startPage.patch
+# 2ce579fac5ddd3aade5fe8d7c080a8a9  - git-ptx-patches magic
diff --git a/rules/host-patchelf.in b/rules/host-patchelf.in
new file mode 100644
index 000000000000..31c42953cdee
--- /dev/null
+++ b/rules/host-patchelf.in
@@ -0,0 +1,15 @@
+## SECTION=hosttools_noprompt
+## SECTION=hosttools_platform
+
+config HOST_PATCHELF
+	tristate
+	default y if ALLYES
+	help
+	  PatchELF is a simple utility for modifying existing ELF
+	  executables and libraries.  In particular, it can do the
+	  following:
+	  * Change the dynamic loader ("ELF interpreter") of
+            executables
+	  * Change the RPATH of executables and libraries
+	  * Remove declared dependencies on dynamic libraries
+            (DT_NEEDED entries)
diff --git a/rules/host-patchelf.make b/rules/host-patchelf.make
new file mode 100644
index 000000000000..a56436a8c314
--- /dev/null
+++ b/rules/host-patchelf.make
@@ -0,0 +1,34 @@
+# -*-makefile-*-
+#
+# Copyright (C) 2018, 2019 by Marc Kleine-Budde <mkl@pengutronix.de>
+#
+# See CREDITS for details about who has contributed to this project.
+#
+# For further information about the PTXdist project and license conditions
+# see the README file.
+#
+
+#
+# We provide this package
+#
+HOST_PACKAGES-$(PTXCONF_HOST_PATCHELF) += host-patchelf
+
+#
+# Paths and names
+#
+HOST_PATCHELF_VERSION	:= 0.10
+HOST_PATCHELF_MD5	:= 228ade8c1b4033670bcf7f77c0ea1fb7
+HOST_PATCHELF		:= patchelf-$(HOST_PATCHELF_VERSION)
+HOST_PATCHELF_SUFFIX	:= tar.gz
+HOST_PATCHELF_URL	:= https://nixos.org/releases/patchelf/$(HOST_PATCHELF)/$(HOST_PATCHELF).$(HOST_PATCHELF_SUFFIX)
+HOST_PATCHELF_SOURCE	:= $(SRCDIR)/$(HOST_PATCHELF).$(HOST_PATCHELF_SUFFIX)
+HOST_PATCHELF_DIR	:= $(HOST_BUILDDIR)/$(HOST_PATCHELF)
+HOST_PATCHELF_LICENSE	:= GPL-3.0-or-later
+
+# ----------------------------------------------------------------------------
+# Prepare
+# ----------------------------------------------------------------------------
+
+HOST_PATCHELF_CONF_TOOL	:= autoconf
+
+# vim: syntax=make
-- 
2.20.1


_______________________________________________
ptxdist mailing list
ptxdist@pengutronix.de

                 reply	other threads:[~2019-05-07 13:09 UTC|newest]

Thread overview: [no followups] expand[flat|nested]  mbox.gz  Atom feed

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20190507130907.25114-1-mkl@pengutronix.de \
    --to=mkl@pengutronix.de \
    --cc=ptxdist@pengutronix.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox