diff options
author | Alexander Kanavin <alex.kanavin@gmail.com> | 2022-08-11 21:58:05 +0200 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2022-08-14 08:13:32 +0100 |
commit | fd65379613ad0ee7b1077ba95399884727095a75 (patch) | |
tree | c4b763378e43b3b082cd409756d26f4967fbea4a | |
parent | 51aa1c66ddedf3a6b915a464fe3f70924fd5a480 (diff) | |
download | poky-fd65379613ad0ee7b1077ba95399884727095a75.tar.gz |
patchelf: replace a rejected patch with an equivalent uninative.bbclass tweak
This was the original reason to add the patch:
https://git.openembedded.org/openembedded-core/commit/?id=18efcbcb896239c64fedd009ce57f3f0c668cbc0
and this is the upstream discussion which suggests handling
read-only files explicitly outside of patchelf:
https://github.com/NixOS/patchelf/pull/89
(From OE-Core rev: 728775c87a7e35a03408675ce1c7a8cd061b2fda)
Signed-off-by: Alexander Kanavin <alex@linutronix.de>
Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r-- | meta/classes-global/uninative.bbclass | 2 | ||||
-rw-r--r-- | meta/recipes-devtools/patchelf/patchelf/handle-read-only-files.patch | 63 | ||||
-rw-r--r-- | meta/recipes-devtools/patchelf/patchelf_0.15.0.bb | 1 |
3 files changed, 2 insertions, 64 deletions
diff --git a/meta/classes-global/uninative.bbclass b/meta/classes-global/uninative.bbclass index 4b7fb36449..42c5f8fdf2 100644 --- a/meta/classes-global/uninative.bbclass +++ b/meta/classes-global/uninative.bbclass | |||
@@ -173,5 +173,7 @@ python uninative_changeinterp () { | |||
173 | if not elf.isDynamic(): | 173 | if not elf.isDynamic(): |
174 | continue | 174 | continue |
175 | 175 | ||
176 | os.chmod(f, s[stat.ST_MODE] | stat.S_IWUSR) | ||
176 | subprocess.check_output(("patchelf-uninative", "--set-interpreter", d.getVar("UNINATIVE_LOADER"), f), stderr=subprocess.STDOUT) | 177 | subprocess.check_output(("patchelf-uninative", "--set-interpreter", d.getVar("UNINATIVE_LOADER"), f), stderr=subprocess.STDOUT) |
178 | os.chmod(f, s[stat.ST_MODE]) | ||
177 | } | 179 | } |
diff --git a/meta/recipes-devtools/patchelf/patchelf/handle-read-only-files.patch b/meta/recipes-devtools/patchelf/patchelf/handle-read-only-files.patch deleted file mode 100644 index 76ad8d9d4d..0000000000 --- a/meta/recipes-devtools/patchelf/patchelf/handle-read-only-files.patch +++ /dev/null | |||
@@ -1,63 +0,0 @@ | |||
1 | From 38b3d65f4a79d39ad9cdf841f2b3b29fd0c961ca Mon Sep 17 00:00:00 2001 | ||
2 | From: Fabio Berton <fabio.berton@ossystems.com.br> | ||
3 | Date: Fri, 9 Sep 2016 16:00:42 -0300 | ||
4 | Subject: [PATCH] handle read-only files | ||
5 | |||
6 | Patch from: | ||
7 | https://github.com/darealshinji/patchelf/commit/40e66392bc4b96e9b4eda496827d26348a503509 | ||
8 | |||
9 | Upstream-Status: Denied [https://github.com/NixOS/patchelf/pull/89] | ||
10 | |||
11 | Signed-off-by: Fabio Berton <fabio.berton@ossystems.com.br> | ||
12 | --- | ||
13 | src/patchelf.cc | 18 +++++++++++++----- | ||
14 | 1 file changed, 13 insertions(+), 5 deletions(-) | ||
15 | |||
16 | diff --git a/src/patchelf.cc b/src/patchelf.cc | ||
17 | index 49accae..fb6c7ed 100644 | ||
18 | --- a/src/patchelf.cc | ||
19 | +++ b/src/patchelf.cc | ||
20 | @@ -378,8 +378,16 @@ void ElfFile<ElfFileParamNames>::sortShdrs() | ||
21 | |||
22 | static void writeFile(const std::string & fileName, const FileContents & contents) | ||
23 | { | ||
24 | + struct stat st; | ||
25 | + | ||
26 | debug("writing %s\n", fileName.c_str()); | ||
27 | |||
28 | + if (stat(fileName.c_str(), &st) != 0) | ||
29 | + error("stat"); | ||
30 | + | ||
31 | + if (chmod(fileName.c_str(), 0600) != 0) | ||
32 | + error("chmod"); | ||
33 | + | ||
34 | int fd = open(fileName.c_str(), O_CREAT | O_TRUNC | O_WRONLY | O_BINARY, 0777); | ||
35 | if (fd == -1) | ||
36 | error("open"); | ||
37 | @@ -395,8 +403,6 @@ static void writeFile(const std::string & fileName, const FileContents & content | ||
38 | bytesWritten += portion; | ||
39 | } | ||
40 | |||
41 | - if (close(fd) >= 0) | ||
42 | - return; | ||
43 | /* | ||
44 | * Just ignore EINTR; a retry loop is the wrong thing to do. | ||
45 | * | ||
46 | @@ -405,9 +411,11 @@ static void writeFile(const std::string & fileName, const FileContents & content | ||
47 | * http://utcc.utoronto.ca/~cks/space/blog/unix/CloseEINTR | ||
48 | * https://sites.google.com/site/michaelsafyan/software-engineering/checkforeintrwheninvokingclosethinkagain | ||
49 | */ | ||
50 | - if (errno == EINTR) | ||
51 | - return; | ||
52 | - error("close"); | ||
53 | + if ((close(fd) < 0) && errno != EINTR) | ||
54 | + error("close"); | ||
55 | + | ||
56 | + if (chmod(fileName.c_str(), st.st_mode) != 0) | ||
57 | + error("chmod"); | ||
58 | } | ||
59 | |||
60 | |||
61 | -- | ||
62 | 2.30.2 | ||
63 | |||
diff --git a/meta/recipes-devtools/patchelf/patchelf_0.15.0.bb b/meta/recipes-devtools/patchelf/patchelf_0.15.0.bb index 389a0a9f40..e07775f574 100644 --- a/meta/recipes-devtools/patchelf/patchelf_0.15.0.bb +++ b/meta/recipes-devtools/patchelf/patchelf_0.15.0.bb | |||
@@ -5,7 +5,6 @@ HOMEPAGE = "https://github.com/NixOS/patchelf" | |||
5 | LICENSE = "GPL-3.0-only" | 5 | LICENSE = "GPL-3.0-only" |
6 | 6 | ||
7 | SRC_URI = "git://github.com/NixOS/patchelf;protocol=https;branch=master \ | 7 | SRC_URI = "git://github.com/NixOS/patchelf;protocol=https;branch=master \ |
8 | file://handle-read-only-files.patch \ | ||
9 | " | 8 | " |
10 | SRCREV = "49008002562355b0e35075cbc1c42c645ff04e28" | 9 | SRCREV = "49008002562355b0e35075cbc1c42c645ff04e28" |
11 | 10 | ||