From: Rich Felker Date: Fri, 5 Oct 2012 05:15:25 +0000 (-0400) Subject: fix race condition in dlopen X-Git-Tag: v0.9.7~58 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=642b7593c3b3488d229488a436bab294dcc27ee9;p=oweals%2Fmusl.git fix race condition in dlopen orig_tail was being saved before the lock was obtained, allowing dlopen failure to roll-back other dlopens that had succeeded. --- diff --git a/src/ldso/dynlink.c b/src/ldso/dynlink.c index e09f0715..2bbd492a 100644 --- a/src/ldso/dynlink.c +++ b/src/ldso/dynlink.c @@ -886,7 +886,7 @@ void *__dynlink(int argc, char **argv) void *dlopen(const char *file, int mode) { - struct dso *volatile p, *orig_tail = tail, *next; + struct dso *volatile p, *orig_tail, *next; size_t i; int cs; @@ -895,6 +895,8 @@ void *dlopen(const char *file, int mode) pthread_setcancelstate(PTHREAD_CANCEL_DISABLE, &cs); pthread_rwlock_wrlock(&lock); + orig_tail = tail; + if (setjmp(rtld_fail)) { /* Clean up anything new that was (partially) loaded */ if (p->deps) for (i=0; p->deps[i]; i++)