don't fail pthread_sigmask/sigprocmask on invalid how when set is null
authorRich Felker <dalias@aerifal.cx>
Wed, 19 Dec 2018 01:01:20 +0000 (20:01 -0500)
committerRich Felker <dalias@aerifal.cx>
Wed, 19 Dec 2018 01:01:20 +0000 (20:01 -0500)
the resolution of Austin Group issue #1132 changes the requirement to
fail so that it only applies when the set argument (new mask) is
non-null. this change was made for consistency with the description,
which specified "if set is a null pointer, the value of the argument
how is not significant".

src/thread/pthread_sigmask.c

index 88c333f6b682b0c3db71fc35b5e7ed69636272a4..f188782a3277ed6dbcadb1cb8b8af90dc73efbdd 100644 (file)
@@ -5,7 +5,7 @@
 int pthread_sigmask(int how, const sigset_t *restrict set, sigset_t *restrict old)
 {
        int ret;
-       if ((unsigned)how - SIG_BLOCK > 2U) return EINVAL;
+       if (set && (unsigned)how - SIG_BLOCK > 2U) return EINVAL;
        ret = -__syscall(SYS_rt_sigprocmask, how, set, old, _NSIG/8);
        if (!ret && old) {
                if (sizeof old->__bits[0] == 8) {