summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2014-11-23 16:17:57 -0500
committerRich Felker <dalias@aerifal.cx>2014-11-23 16:17:57 -0500
commitd8dc2b7c0289b12eeef4feff65e3c918111b0f55 (patch)
tree6e5d4233dc9b2d3e534581d45f0b2e71c2e30521
parent9911754b198aaf1e2b0e98951766a9d83c277c67 (diff)
downloadmusl-d8dc2b7c0289b12eeef4feff65e3c918111b0f55.tar.gz
musl-d8dc2b7c0289b12eeef4feff65e3c918111b0f55.tar.bz2
musl-d8dc2b7c0289b12eeef4feff65e3c918111b0f55.tar.xz
musl-d8dc2b7c0289b12eeef4feff65e3c918111b0f55.zip
adapt dynamic linker for new binutils versions that omit DT_RPATH
the new DT_RUNPATH semantics for search order are always used, and since binutils had always set both DT_RPATH and DT_RUNPATH when the latter was used, processing only DT_RPATH worked fine. however, recent binutils has stopped generating DT_RPATH when DT_RUNPATH is used, which broke support for this feature completely.
-rw-r--r--src/ldso/dynlink.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/src/ldso/dynlink.c b/src/ldso/dynlink.c
index 1de430c6..00af8865 100644
--- a/src/ldso/dynlink.c
+++ b/src/ldso/dynlink.c
@@ -645,6 +645,8 @@ static void decode_dyn(struct dso *p)
p->hashtab = (void *)(p->base + dyn[DT_HASH]);
if (dyn[0]&(1<<DT_RPATH))
p->rpath_orig = (void *)(p->strings + dyn[DT_RPATH]);
+ if (dyn[0]&(1<<DT_RUNPATH))
+ p->rpath_orig = (void *)(p->strings + dyn[DT_RUNPATH]);
if (search_vec(p->dynv, dyn, DT_GNU_HASH))
p->ghashtab = (void *)(p->base + *dyn);
if (search_vec(p->dynv, dyn, DT_VERSYM))