Source-Changes-HG archive

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

[src/trunk]: src/sys/kern In ksem_close_fop(), if we get a pshared semaphore ...



details:   https://anonhg.NetBSD.org/src/rev/d7c61bdbabe6
branches:  trunk
changeset: 996588:d7c61bdbabe6
user:      thorpej <thorpej%NetBSD.org@localhost>
date:      Tue Feb 05 07:14:32 2019 +0000

description:
In ksem_close_fop(), if we get a pshared semaphore that's not already
been marked dead, make sure we mark it so if the owner proc is the proc
closing it.  (This case can happen if a process sem_init()'s a pshared
semaphore and then exits without destroying it.)

Fixes kern/53942.

diffstat:

 sys/kern/uipc_sem.c |  18 ++++++++++++------
 1 files changed, 12 insertions(+), 6 deletions(-)

diffs (41 lines):

diff -r 053bdda1d6ee -r d7c61bdbabe6 sys/kern/uipc_sem.c
--- a/sys/kern/uipc_sem.c       Tue Feb 05 06:46:47 2019 +0000
+++ b/sys/kern/uipc_sem.c       Tue Feb 05 07:14:32 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: uipc_sem.c,v 1.52 2019/02/03 03:20:23 thorpej Exp $    */
+/*     $NetBSD: uipc_sem.c,v 1.53 2019/02/05 07:14:32 thorpej Exp $    */
 
 /*-
  * Copyright (c) 2011, 2019 The NetBSD Foundation, Inc.
@@ -60,7 +60,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: uipc_sem.c,v 1.52 2019/02/03 03:20:23 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: uipc_sem.c,v 1.53 2019/02/05 07:14:32 thorpej Exp $");
 
 #include <sys/param.h>
 #include <sys/kernel.h>
@@ -840,12 +840,18 @@
 {
        ksem_t *ks = fp->f_ksem;
 
-       if (ks->ks_pshared_id != 0 && ks->ks_pshared_proc != curproc) {
-               /* Do nothing if this is not the creator. */
-               return 0;
+       mutex_enter(&ks->ks_lock);
+
+       if (ks->ks_pshared_id) {
+               if (ks->ks_pshared_proc != curproc) {
+                       /* Do nothing if this is not the creator. */
+                       mutex_exit(&ks->ks_lock);
+                       return 0;
+               }
+               /* Mark this semaphore as dead. */
+               ks->ks_pshared_proc = NULL;
        }
 
-       mutex_enter(&ks->ks_lock);
        ksem_release(ks, -1);
        return 0;
 }



Home | Main Index | Thread Index | Old Index