summaryrefslogtreecommitdiff
path: root/src/thread/pthread_create.c
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2011-04-13 20:47:01 -0400
committerRich Felker <dalias@aerifal.cx>2011-04-13 20:47:01 -0400
commit9beb6330c08839e8bb2ebcd129c97c395d9d327e (patch)
treeebd39cb4fae2cc1116adca1d38ae539be705e8ec /src/thread/pthread_create.c
parent19c1830eaaab05652d87b5ee9557d0d7a40c2f06 (diff)
downloadmusl-9beb6330c08839e8bb2ebcd129c97c395d9d327e.tar.gz
musl-9beb6330c08839e8bb2ebcd129c97c395d9d327e.tar.bz2
musl-9beb6330c08839e8bb2ebcd129c97c395d9d327e.tar.xz
musl-9beb6330c08839e8bb2ebcd129c97c395d9d327e.zip
simplify cancellation point handling
we take advantage of the fact that unless self->cancelpt is 1, cancellation cannot happen. so just increment it by 2 to temporarily block cancellation. this drops pthread_create.o well under 1k.
Diffstat (limited to 'src/thread/pthread_create.c')
-rw-r--r--src/thread/pthread_create.c15
1 files changed, 2 insertions, 13 deletions
diff --git a/src/thread/pthread_create.c b/src/thread/pthread_create.c
index acbd5a41..a7826504 100644
--- a/src/thread/pthread_create.c
+++ b/src/thread/pthread_create.c
@@ -63,19 +63,8 @@ static void cancel_handler(int sig, siginfo_t *si, void *ctx)
static void cancelpt(int x)
{
struct pthread *self = __pthread_self();
- switch (x) {
- case 1:
- self->cancelpoint++;
- case 0:
- if (self->cancel && self->cancelpoint==1 && !self->canceldisable)
- docancel(self);
- break;
- case -1:
- self->cancelpoint--;
- break;
- default:
- self->canceldisable += x;
- }
+ if ((self->cancelpoint+=x)==1 && self->cancel
+ && x<2U && !self->canceldisable) docancel(self);
}
static void init_threads()