recheck cancellation disabled flag after syscall returns EINTR
authorRich Felker <dalias@aerifal.cx>
Tue, 19 Apr 2011 00:50:37 +0000 (20:50 -0400)
committerRich Felker <dalias@aerifal.cx>
Tue, 19 Apr 2011 00:50:37 +0000 (20:50 -0400)
we already checked before making the syscall, but it's possible that a
signal handler interrupted the blocking syscall and disabled
cancellation, and that this is the cause of EINTR. in this case, the
old behavior was testably wrong.

src/thread/cancel_impl.c

index 1f4ff90..0d80885 100644 (file)
@@ -27,7 +27,7 @@ long (__syscall_cp)(long nr, long u, long v, long w, long x, long y, long z)
        r = __syscall_cp_asm(&self->cp_sp, nr, u, v, w, x, y, z);
        self->cp_ip = old_ip;
        self->cp_sp = old_sp;
-       if (r == -EINTR && self->cancel) __cancel();
+       if (r == -EINTR && self->cancel && !self->canceldisable) __cancel();
        return r;
 }