Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/lib/libpthread Use pthread_barrierattr_t and pthread_barrier...



details:   https://anonhg.NetBSD.org/src/rev/e9a468e0d09c
branches:  trunk
changeset: 1006861:e9a468e0d09c
user:      kamil <kamil%NetBSD.org@localhost>
date:      Wed Jan 29 14:41:57 2020 +0000

description:
Use pthread_barrierattr_t and pthread_barrier_t magic fields

Set respectively _PT_BARRIER_DEAD for pthread_barrier_destroy() and
_PT_BARRIERATTR_DEAD for pthread_barrierattr_destroy().

Validate _PT_BARRIER_MAGIC in pthread_barrier_t and _PT_BARRIERATTR_MAGIC
in pthread_barrierattr_t accordingly.

diffstat:

 lib/libpthread/pthread_barrier.c |  31 ++++++++++++++++++++-----------
 1 files changed, 20 insertions(+), 11 deletions(-)

diffs (89 lines):

diff -r c3b3c3fcbc5e -r e9a468e0d09c lib/libpthread/pthread_barrier.c
--- a/lib/libpthread/pthread_barrier.c  Wed Jan 29 13:54:41 2020 +0000
+++ b/lib/libpthread/pthread_barrier.c  Wed Jan 29 14:41:57 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: pthread_barrier.c,v 1.20 2016/07/03 14:24:58 christos Exp $    */
+/*     $NetBSD: pthread_barrier.c,v 1.21 2020/01/29 14:41:57 kamil Exp $       */
 
 /*-
  * Copyright (c) 2001, 2003, 2006, 2007, 2009 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: pthread_barrier.c,v 1.20 2016/07/03 14:24:58 christos Exp $");
+__RCSID("$NetBSD: pthread_barrier.c,v 1.21 2020/01/29 14:41:57 kamil Exp $");
 
 #include <errno.h>
 
@@ -41,9 +41,9 @@
 pthread_barrier_init(pthread_barrier_t *barrier,
                     const pthread_barrierattr_t *attr, unsigned int count)
 {
-       
-       if (attr != NULL && attr->ptba_magic != _PT_BARRIERATTR_MAGIC)
-               return EINVAL;
+
+       pthread__error(EINVAL, "Invalid barrier attribute",
+           attr == NULL || attr->ptba_magic == _PT_BARRIERATTR_MAGIC);
        if (count == 0)
                return EINVAL;
 
@@ -59,10 +59,13 @@
 pthread_barrier_destroy(pthread_barrier_t *barrier)
 {
 
-       if (barrier->ptb_magic != _PT_BARRIER_MAGIC)
-               return EINVAL;
+       pthread__error(EINVAL, "Invalid barrier",
+           barrier->ptb_magic == _PT_BARRIER_MAGIC);
        if (barrier->ptb_curcount != 0)
                return EBUSY;
+
+       barrier->ptb_magic = _PT_BARRIER_DEAD;
+
        return 0;
 }
 
@@ -73,8 +76,8 @@
        pthread_t self;
        unsigned int gen;
 
-       if (barrier->ptb_magic != _PT_BARRIER_MAGIC)
-               return EINVAL;
+       pthread__error(EINVAL, "Invalid barrier",
+           barrier->ptb_magic == _PT_BARRIER_MAGIC);
 
        /*
         * A single arbitrary thread is supposed to return
@@ -123,6 +126,9 @@
     int * __restrict pshared)
 {
 
+       pthread__error(EINVAL, "Invalid barrier attribute",
+           attr->ptba_magic == _PT_BARRIERATTR_MAGIC);
+
        *pshared = PTHREAD_PROCESS_PRIVATE;
        return 0;
 }
@@ -131,6 +137,9 @@
 pthread_barrierattr_setpshared(pthread_barrierattr_t *attr, int pshared)
 {
 
+       pthread__error(EINVAL, "Invalid barrier attribute",
+           attr->ptba_magic == _PT_BARRIERATTR_MAGIC);
+
        switch(pshared) {
        case PTHREAD_PROCESS_PRIVATE:
                return 0;
@@ -153,8 +162,8 @@
 pthread_barrierattr_destroy(pthread_barrierattr_t *attr)
 {
 
-       if (attr->ptba_magic != _PT_BARRIERATTR_MAGIC)
-               return EINVAL;
+       pthread__error(EINVAL, "Invalid barrier attribute",
+           attr->ptba_magic == _PT_BARRIERATTR_MAGIC);
        attr->ptba_magic = _PT_BARRIERATTR_DEAD;
        return 0;
 }



Home | Main Index | Thread Index | Old Index