|
Message-Id: <1585512901-18979-1-git-send-email-rcombs@rcombs.me> Date: Sun, 29 Mar 2020 15:15:00 -0500 From: rcombs <rcombs@...mbs.me> To: musl@...ts.openwall.com Subject: [PATCH 1/2] ldso: when run via CLI, set auxv as if the app was loaded by the kernel --- ldso/dynlink.c | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/ldso/dynlink.c b/ldso/dynlink.c index 6468f20..a9144e2 100644 --- a/ldso/dynlink.c +++ b/ldso/dynlink.c @@ -1808,6 +1808,22 @@ void __dls3(size_t *sp, size_t *auxv) } dprintf(1, "\t%s (%p)\n", ldso.name, ldso.base); } + + // Make it look to the app as if it was loaded by the kernel + for (i=0; auxv[i]; i+=2) { + if (auxv[i] == AT_BASE) + auxv[i + 1] = (size_t)ldso.base; + if (auxv[i] == AT_PHDR) + auxv[i + 1] = (size_t)app.phdr; + if (auxv[i] == AT_ENTRY) + auxv[i + 1] = aux[AT_ENTRY]; + if (auxv[i] == AT_PHNUM) + auxv[i + 1] = app.phnum; + if (auxv[i] == AT_PHENT) + auxv[i + 1] = app.phentsize; + if (auxv[i] == AT_EXECFN) + auxv[i + 1] = (size_t)app.name; + } } if (app.tls.size) { libc.tls_head = tls_tail = &app.tls; -- 2.7.4
Powered by blists - more mailing lists
Confused about mailing lists and their use? Read about mailing lists on Wikipedia and check out these guidelines on proper formatting of your messages.