Source-Changes-HG archive

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

[src/trunk]: src/lib/libc/gen PR/53904: Jintao Zhu: Use a mutex instead of an...



details:   https://anonhg.NetBSD.org/src/rev/636451a399ae
branches:  trunk
changeset: 996231:636451a399ae
user:      christos <christos%NetBSD.org@localhost>
date:      Thu Jan 24 18:01:38 2019 +0000

description:
PR/53904: Jintao Zhu: Use a mutex instead of an rwlock to assure thread safety

diffstat:

 lib/libc/gen/popen.c |  55 +++++++++++++++++++++++----------------------------
 1 files changed, 25 insertions(+), 30 deletions(-)

diffs (132 lines):

diff -r 2d4b08f6c619 -r 636451a399ae lib/libc/gen/popen.c
--- a/lib/libc/gen/popen.c      Thu Jan 24 13:05:59 2019 +0000
+++ b/lib/libc/gen/popen.c      Thu Jan 24 18:01:38 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: popen.c,v 1.35 2015/02/02 22:07:05 christos Exp $      */
+/*     $NetBSD: popen.c,v 1.36 2019/01/24 18:01:38 christos Exp $      */
 
 /*
  * Copyright (c) 1988, 1993
@@ -37,7 +37,7 @@
 #if 0
 static char sccsid[] = "@(#)popen.c    8.3 (Berkeley) 5/3/95";
 #else
-__RCSID("$NetBSD: popen.c,v 1.35 2015/02/02 22:07:05 christos Exp $");
+__RCSID("$NetBSD: popen.c,v 1.36 2019/01/24 18:01:38 christos Exp $");
 #endif
 #endif /* LIBC_SCCS and not lint */
 
@@ -73,7 +73,20 @@
 } *pidlist; 
        
 #ifdef _REENTRANT
-static rwlock_t pidlist_lock = RWLOCK_INITIALIZER;
+static  mutex_t pidlist_mutex = MUTEX_INITIALIZER;
+# define MUTEX_LOCK() \
+    do { \
+           if (__isthreaded) \
+                   mutex_lock(&pidlist_mutex); \
+    } while (/*CONSTCOND*/0)
+# define MUTEX_UNLOCK() \
+    do { \
+           if (__isthreaded) \
+                   mutex_unlock(&pidlist_mutex); \
+    } while (/*CONSTCOND*/0)
+#else
+# define MUTEX_LOCK() __nothing
+# define MUTEX_UNLOCK() __nothing
 #endif
 
 static struct pid *
@@ -183,17 +196,13 @@
        if ((cur = pdes_get(pdes, &type)) == NULL)
                return NULL;
 
-#ifdef _REENTRANT
-       (void)rwlock_rdlock(&pidlist_lock);
-#endif
+       MUTEX_LOCK();
        (void)__readlockenv();
        switch (pid = vfork()) {
        case -1:                        /* Error. */
                serrno = errno;
                (void)__unlockenv();
-#ifdef _REENTRANT
-               (void)rwlock_unlock(&pidlist_lock);
-#endif
+               MUTEX_UNLOCK();
                pdes_error(pdes, cur);
                errno = serrno;
                return NULL;
@@ -208,9 +217,7 @@
 
        pdes_parent(pdes, cur, pid, type);
 
-#ifdef _REENTRANT
-       (void)rwlock_unlock(&pidlist_lock);
-#endif
+       MUTEX_UNLOCK();
 
        return cur->fp;
 }
@@ -228,15 +235,11 @@
        if ((cur = pdes_get(pdes, &type)) == NULL)
                return NULL;
 
-#ifdef _REENTRANT
-       (void)rwlock_rdlock(&pidlist_lock);
-#endif
+       MUTEX_LOCK();
        switch (pid = vfork()) {
        case -1:                        /* Error. */
                serrno = errno;
-#ifdef _REENTRANT
-               (void)rwlock_unlock(&pidlist_lock);
-#endif
+               MUTEX_UNLOCK();
                pdes_error(pdes, cur);
                errno = serrno;
                return NULL;
@@ -250,9 +253,7 @@
 
        pdes_parent(pdes, cur, pid, type);
 
-#ifdef _REENTRANT
-       (void)rwlock_unlock(&pidlist_lock);
-#endif
+       MUTEX_UNLOCK();
 
        return cur->fp;
 }
@@ -271,18 +272,14 @@
 
        _DIAGASSERT(iop != NULL);
 
-#ifdef _REENTRANT
-       rwlock_wrlock(&pidlist_lock);
-#endif
+       MUTEX_LOCK();
 
        /* Find the appropriate file pointer. */
        for (last = NULL, cur = pidlist; cur; last = cur, cur = cur->next)
                if (cur->fp == iop)
                        break;
        if (cur == NULL) {
-#ifdef _REENTRANT
-               (void)rwlock_unlock(&pidlist_lock);
-#endif
+               MUTEX_UNLOCK();
                errno = ESRCH;
                return -1;
        }
@@ -295,9 +292,7 @@
        else
                last->next = cur->next;
 
-#ifdef _REENTRANT
-       (void)rwlock_unlock(&pidlist_lock);
-#endif
+       MUTEX_UNLOCK();
 
        do {
                pid = waitpid(cur->pid, &pstat, 0);



Home | Main Index | Thread Index | Old Index