report sem value overflows in sem_post
authorRich Felker <dalias@aerifal.cx>
Wed, 26 Oct 2011 04:28:47 +0000 (00:28 -0400)
committerRich Felker <dalias@aerifal.cx>
Wed, 26 Oct 2011 04:28:47 +0000 (00:28 -0400)
this is not required by the standard, but it's nicer than corrupting
the state and rather inexpensive.

src/thread/sem_post.c

index 148ab78..14a2dfe 100644 (file)
@@ -7,6 +7,10 @@ int sem_post(sem_t *sem)
        do {
                val = sem->__val[0];
                waiters = sem->__val[1];
+               if (val == SEM_VALUE_MAX) {
+                       errno = EOVERFLOW;
+                       return -1;
+               }
        } while (a_cas(sem->__val, val, val+1+(val<0)) != val);
        if (val<0 || waiters) __wake(sem->__val, 1, 0);
        return 0;