Patrick Williams | 213cb26 | 2021-08-07 19:21:33 -0500 | [diff] [blame] | 1 | From 29517900352336708495d41902b5b7e8cc9a401a Mon Sep 17 00:00:00 2001 |
Andrew Geissler | 82c905d | 2020-04-13 13:39:40 -0500 | [diff] [blame] | 2 | From: Khem Raj <raj.khem@gmail.com> |
| 3 | Date: Mon, 2 Mar 2015 01:27:17 +0000 |
Andrew Geissler | d1e8949 | 2021-02-12 15:35:20 -0600 | [diff] [blame] | 4 | Subject: [PATCH] Only generate an RPATH entry if LD_RUN_PATH is not empty |
Andrew Geissler | 82c905d | 2020-04-13 13:39:40 -0500 | [diff] [blame] | 5 | |
| 6 | for cases where -rpath isn't specified. debian (#151024) |
| 7 | |
| 8 | Upstream-Status: Pending |
| 9 | |
| 10 | Signed-off-by: Chris Chimelis <chris@debian.org> |
| 11 | Signed-off-by: Khem Raj <raj.khem@gmail.com> |
| 12 | --- |
| 13 | ld/ldelf.c | 4 ++++ |
| 14 | 1 file changed, 4 insertions(+) |
| 15 | |
| 16 | diff --git a/ld/ldelf.c b/ld/ldelf.c |
Patrick Williams | 213cb26 | 2021-08-07 19:21:33 -0500 | [diff] [blame] | 17 | index d1615003ede..6a894285b11 100644 |
Andrew Geissler | 82c905d | 2020-04-13 13:39:40 -0500 | [diff] [blame] | 18 | --- a/ld/ldelf.c |
| 19 | +++ b/ld/ldelf.c |
Patrick Williams | 213cb26 | 2021-08-07 19:21:33 -0500 | [diff] [blame] | 20 | @@ -1250,6 +1250,8 @@ ldelf_after_open (int use_libpath, int native, int is_linux, int is_freebsd, |
Andrew Geissler | 82c905d | 2020-04-13 13:39:40 -0500 | [diff] [blame] | 21 | && command_line.rpath == NULL) |
| 22 | { |
| 23 | path = (const char *) getenv ("LD_RUN_PATH"); |
| 24 | + if ((path) && (strlen (path) == 0)) |
| 25 | + path = NULL; |
| 26 | if (path |
| 27 | && ldelf_search_needed (path, &n, force, |
| 28 | is_linux, elfsize)) |
Patrick Williams | 213cb26 | 2021-08-07 19:21:33 -0500 | [diff] [blame] | 29 | @@ -1610,6 +1612,8 @@ ldelf_before_allocation (char *audit, char *depaudit, |
Andrew Geissler | 82c905d | 2020-04-13 13:39:40 -0500 | [diff] [blame] | 30 | rpath = command_line.rpath; |
| 31 | if (rpath == NULL) |
| 32 | rpath = (const char *) getenv ("LD_RUN_PATH"); |
| 33 | + if ((rpath) && (strlen (rpath) == 0)) |
| 34 | + rpath = NULL; |
| 35 | |
| 36 | for (abfd = link_info.input_bfds; abfd; abfd = abfd->link.next) |
| 37 | if (bfd_get_flavour (abfd) == bfd_target_elf_flavour) |