diff options
author | Rich Felker <dalias@aerifal.cx> | 2012-02-09 21:24:56 -0500 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2012-02-09 21:24:56 -0500 |
commit | 2230218c283af7fbff08167685f17dad8d748f14 (patch) | |
tree | 2206cd094ea207e0cf15155654138b1f60f2d65a /src/thread/cancellation.c | |
parent | afc35d5efde48b82a7786d9c89b115965da6b637 (diff) | |
download | musl-2230218c283af7fbff08167685f17dad8d748f14.tar.gz musl-2230218c283af7fbff08167685f17dad8d748f14.tar.xz musl-2230218c283af7fbff08167685f17dad8d748f14.zip |
small fix for new pthread cleanup stuff
even if pthread_create/exit code is not linked, run flag needs to be checked and cleanup function potentially run on pop. thus, move the code to the module that's always linked when pthread_cleanup_push/pop is used.
Diffstat (limited to 'src/thread/cancellation.c')
-rw-r--r-- | src/thread/cancellation.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/src/thread/cancellation.c b/src/thread/cancellation.c index 967705a9..23d23d14 100644 --- a/src/thread/cancellation.c +++ b/src/thread/cancellation.c @@ -11,6 +11,7 @@ void _pthread_cleanup_push(struct __ptcb *cb, void (*f)(void *), void *x) void _pthread_cleanup_pop(struct __ptcb *cb, int run) { __do_cleanup_pop(cb, run); + if (run) cb->__f(cb->__x); } static void dummy() |