summaryrefslogtreecommitdiff
path: root/src/ldso
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2012-08-25 17:24:46 -0400
committerRich Felker <dalias@aerifal.cx>2012-08-25 17:24:46 -0400
commit731e8ffdcf6877c04092aa9fbd2b17907b8846c7 (patch)
tree0212e1ff8516eceab38bd1552322bee7dd11841c /src/ldso
parent2bd05a4fc26c297754f7ee5745a1c3b072a44b7d (diff)
downloadmusl-731e8ffdcf6877c04092aa9fbd2b17907b8846c7.tar.gz
musl-731e8ffdcf6877c04092aa9fbd2b17907b8846c7.tar.bz2
musl-731e8ffdcf6877c04092aa9fbd2b17907b8846c7.tar.xz
musl-731e8ffdcf6877c04092aa9fbd2b17907b8846c7.zip
ensure canary is setup if stack-prot libs are dlopen'd into non-ssp app
previously, this usage could lead to a crash if the thread pointer was still uninitialized, and otherwise would just cause the canary to be zero (less secure).
Diffstat (limited to 'src/ldso')
-rw-r--r--src/ldso/dynlink.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/src/ldso/dynlink.c b/src/ldso/dynlink.c
index d7d68002..6ffda49c 100644
--- a/src/ldso/dynlink.c
+++ b/src/ldso/dynlink.c
@@ -81,6 +81,7 @@ static int ldso_fail;
static jmp_buf rtld_fail;
static pthread_rwlock_t lock;
static struct debug debug;
+static size_t *auxv;
struct debug *_dl_debug_addr = &debug;
@@ -603,7 +604,7 @@ void _dl_debug_state(void)
void *__dynlink(int argc, char **argv)
{
- size_t *auxv, aux[AUX_CNT] = {0};
+ size_t aux[AUX_CNT] = {0};
size_t i;
Phdr *phdr;
Ehdr *ehdr;
@@ -838,6 +839,8 @@ void *dlopen(const char *file, int mode)
p->global = 1;
}
+ if (ssp_used) __init_ssp(auxv);
+
_dl_debug_state();
do_init_fini(tail);