Source-Changes-HG archive

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

[src/trunk]: src/sys/nfs PR/40491: From Tobias Ulmer in tech-kern@:



details:   https://anonhg.NetBSD.org/src/rev/4c551092fce4
branches:  trunk
changeset: 358901:4c551092fce4
user:      christos <christos%NetBSD.org@localhost>
date:      Sun Jan 21 20:36:49 2018 +0000

description:
PR/40491: From Tobias Ulmer in tech-kern@:
1. Protect the nfs request queue with its own mutex
2. make the nfs_receive queue check for signals so that intr mounts
   can be interrupted.
XXX: pullup-8

diffstat:

 sys/nfs/nfs.h            |   3 ++-
 sys/nfs/nfs_clntsocket.c |  18 +++++++++++++-----
 sys/nfs/nfs_socket.c     |  15 +++++++++------
 sys/nfs/nfs_subs.c       |   6 ++++--
 4 files changed, 28 insertions(+), 14 deletions(-)

diffs (192 lines):

diff -r a07d6168ff39 -r 4c551092fce4 sys/nfs/nfs.h
--- a/sys/nfs/nfs.h     Sun Jan 21 18:37:33 2018 +0000
+++ b/sys/nfs/nfs.h     Sun Jan 21 20:36:49 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: nfs.h,v 1.75 2015/04/20 13:12:24 riastradh Exp $       */
+/*     $NetBSD: nfs.h,v 1.76 2018/01/21 20:36:49 christos Exp $        */
 /*
  * Copyright (c) 1989, 1993, 1995
  *     The Regents of the University of California.  All rights reserved.
@@ -341,6 +341,7 @@
  * Queue head for nfsreq's
  */
 extern TAILQ_HEAD(nfsreqhead, nfsreq) nfs_reqq;
+extern kmutex_t nfs_reqq_lock;
 
 /* Flag values for r_flags */
 #define R_TIMING       0x01            /* timing request (in mntp) */
diff -r a07d6168ff39 -r 4c551092fce4 sys/nfs/nfs_clntsocket.c
--- a/sys/nfs/nfs_clntsocket.c  Sun Jan 21 18:37:33 2018 +0000
+++ b/sys/nfs/nfs_clntsocket.c  Sun Jan 21 20:36:49 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: nfs_clntsocket.c,v 1.5 2016/06/17 14:28:29 christos Exp $      */
+/*     $NetBSD: nfs_clntsocket.c,v 1.6 2018/01/21 20:36:49 christos Exp $      */
 
 /*
  * Copyright (c) 1989, 1991, 1993, 1995
@@ -39,7 +39,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: nfs_clntsocket.c,v 1.5 2016/06/17 14:28:29 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: nfs_clntsocket.c,v 1.6 2018/01/21 20:36:49 christos Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_nfs.h"
@@ -294,9 +294,11 @@
                        rcvflg = 0;
                        error =  (*so->so_receive)(so, getnam, &auio, mp,
                                NULL, &rcvflg);
-                       if (error == EWOULDBLOCK &&
-                           (rep->r_flags & R_SOFTTERM))
-                               return (EINTR);
+                       if (error == EWOULDBLOCK) {
+                               int intr = nfs_sigintr(rep->r_nmp, rep, l);
+                               if (intr)
+                                       error = intr;
+                       }
                } while (error == EWOULDBLOCK);
                len -= auio.uio_resid;
                if (!error && *mp == NULL)
@@ -403,6 +405,7 @@
                 * Iff no match, just drop the datagram
                 */
                s = splsoftnet();
+               mutex_enter(&nfs_reqq_lock);
                TAILQ_FOREACH(rep, &nfs_reqq, r_chain) {
                        if (rep->r_mrep != NULL || rxid != rep->r_xid)
                                continue;
@@ -468,6 +471,7 @@
                        nmp->nm_timeouts = 0;
                        break;
                }
+               mutex_exit(&nfs_reqq_lock);
                splx(s);
                nfs_rcvunlock(nmp);
                /*
@@ -653,7 +657,9 @@
         * to put it LAST so timer finds oldest requests first.
         */
        s = splsoftnet();
+       mutex_enter(&nfs_reqq_lock);
        TAILQ_INSERT_TAIL(&nfs_reqq, rep, r_chain);
+       mutex_exit(&nfs_reqq_lock);
        nfs_timer_start();
 
        /*
@@ -695,7 +701,9 @@
         * RPC done, unlink the request.
         */
        s = splsoftnet();
+       mutex_enter(&nfs_reqq_lock);
        TAILQ_REMOVE(&nfs_reqq, rep, r_chain);
+       mutex_exit(&nfs_reqq_lock);
 
        /*
         * Decrement the outstanding request count.
diff -r a07d6168ff39 -r 4c551092fce4 sys/nfs/nfs_socket.c
--- a/sys/nfs/nfs_socket.c      Sun Jan 21 18:37:33 2018 +0000
+++ b/sys/nfs/nfs_socket.c      Sun Jan 21 20:36:49 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: nfs_socket.c,v 1.198 2016/06/17 14:28:29 christos Exp $        */
+/*     $NetBSD: nfs_socket.c,v 1.199 2018/01/21 20:36:49 christos Exp $        */
 
 /*
  * Copyright (c) 1989, 1991, 1993, 1995
@@ -39,7 +39,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: nfs_socket.c,v 1.198 2016/06/17 14:28:29 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: nfs_socket.c,v 1.199 2018/01/21 20:36:49 christos Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_nfs.h"
@@ -166,6 +166,7 @@
 struct nfsrtt nfsrtt;
 static const int nfs_backoff[8] = { 2, 4, 8, 16, 32, 64, 128, 256, };
 struct nfsreqhead nfs_reqq;
+kmutex_t nfs_reqq_lock;
 static callout_t nfs_timer_ch;
 static struct evcnt nfs_timer_ev;
 static struct evcnt nfs_timer_start_ev;
@@ -385,6 +386,7 @@
         * on old socket.
         */
        s = splsoftnet();
+       mutex_enter(&nfs_reqq_lock);
        TAILQ_FOREACH(rp, &nfs_reqq, r_chain) {
                if (rp->r_nmp == nmp) {
                        if ((rp->r_flags & R_MUSTRESEND) == 0)
@@ -392,6 +394,7 @@
                        rp->r_rexmit = 0;
                }
        }
+       mutex_exit(&nfs_reqq_lock);
        splx(s);
        return (0);
 }
@@ -759,7 +762,7 @@
 
        nfs_timer_ev.ev_count++;
 
-       mutex_enter(softnet_lock);      /* XXX PR 40491 */
+       mutex_enter(&nfs_reqq_lock);
        TAILQ_FOREACH(rep, &nfs_reqq, r_chain) {
                more = true;
                nmp = rep->r_nmp;
@@ -813,7 +816,7 @@
                 *      Resend it
                 * Set r_rtt to -1 in case we fail to send it now.
                 */
-               /* solock(so);          XXX PR 40491 */
+               solock(so);
                rep->r_rtt = -1;
                if (sbspace(&so->so_snd) >= rep->r_mreq->m_pkthdr.len &&
                   ((nmp->nm_flag & NFSMNT_DUMBTIMR) ||
@@ -858,9 +861,9 @@
                                rep->r_rtt = 0;
                        }
                }
-               /* sounlock(so);        XXX PR 40491 */
+               sounlock(so);
        }
-       mutex_exit(softnet_lock);       /* XXX PR 40491 */
+       mutex_exit(&nfs_reqq_lock);
 
        mutex_enter(&nfs_timer_lock);
        if (nfs_timer_srvvec != NULL) {
diff -r a07d6168ff39 -r 4c551092fce4 sys/nfs/nfs_subs.c
--- a/sys/nfs/nfs_subs.c        Sun Jan 21 18:37:33 2018 +0000
+++ b/sys/nfs/nfs_subs.c        Sun Jan 21 20:36:49 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: nfs_subs.c,v 1.229 2017/04/01 19:35:57 riastradh Exp $ */
+/*     $NetBSD: nfs_subs.c,v 1.230 2018/01/21 20:36:49 christos Exp $  */
 
 /*
  * Copyright (c) 1989, 1993
@@ -70,7 +70,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: nfs_subs.c,v 1.229 2017/04/01 19:35:57 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: nfs_subs.c,v 1.230 2018/01/21 20:36:49 christos Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_nfs.h"
@@ -1495,6 +1495,7 @@
         * Initialize reply list and start timer
         */
        TAILQ_INIT(&nfs_reqq);
+       mutex_init(&nfs_reqq_lock, MUTEX_DEFAULT, IPL_NONE);
        nfs_timer_init();
        MOWNER_ATTACH(&nfs_mowner);
 
@@ -1534,6 +1535,7 @@
        if (--nfs_refcount == 0) {
                MOWNER_DETACH(&nfs_mowner);
                nfs_timer_fini();
+               mutex_destroy(&nfs_reqq_lock);
                nfsdreq_fini();
        }
        nfs_v();



Home | Main Index | Thread Index | Old Index