summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/nfs/nfs_kq.c36
-rw-r--r--sys/nfs/nfs_subs.c6
-rw-r--r--sys/nfs/nfs_var.h3
3 files changed, 17 insertions, 28 deletions
diff --git a/sys/nfs/nfs_kq.c b/sys/nfs/nfs_kq.c
index 6a02b57b529..23e72b4576a 100644
--- a/sys/nfs/nfs_kq.c
+++ b/sys/nfs/nfs_kq.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: nfs_kq.c,v 1.3 2007/04/12 18:21:19 thib Exp $ */
+/* $OpenBSD: nfs_kq.c,v 1.4 2007/04/19 14:46:44 thib Exp $ */
/* $NetBSD: nfs_kq.c,v 1.7 2003/10/30 01:43:10 simonb Exp $ */
/*-
@@ -52,6 +52,7 @@ __KERNEL_RCSID(0, "$NetBSD: nfs_kq.c,v 1.7 2003/10/30 01:43:10 simonb Exp $");
#include <sys/unistd.h>
#include <sys/file.h>
#include <sys/kthread.h>
+#include <sys/rwlock.h>
#include <uvm/uvm_extern.h>
#include <uvm/uvm.h>
@@ -75,16 +76,10 @@ struct kevq {
};
SLIST_HEAD(kevqlist, kevq);
-static struct lock nfskevq_lock;
+struct rwlock nfskevq_lock = RWLOCK_INITIALIZER;
static struct proc *pnfskq;
static struct kevqlist kevlist = SLIST_HEAD_INITIALIZER(kevlist);
-void
-nfs_kqinit(void)
-{
- lockinit(&nfskevq_lock, PSOCK, "nfskqlck", 0, 0);
-}
-
/*
* This quite simplistic routine periodically checks for server changes
* of any of the watched files every NFS_MINATTRTIMO/2 seconds.
@@ -110,7 +105,7 @@ nfs_kqpoll(void *arg)
int error;
for(;;) {
- lockmgr(&nfskevq_lock, LK_EXCLUSIVE, NULL);
+ rw_enter_write(&nfskevq_lock);
SLIST_FOREACH(ke, &kevlist, kev_link) {
struct nfsnode *np = VTONFS(ke->vp);
@@ -127,7 +122,7 @@ nfs_kqpoll(void *arg)
* for changes.
*/
ke->flags |= KEVQ_BUSY;
- lockmgr(&nfskevq_lock, LK_RELEASE, NULL);
+ rw_exit_write(&nfskevq_lock);
/* save v_size, nfs_getattr() updates it */
osize = np->n_size;
@@ -164,7 +159,7 @@ nfs_kqpoll(void *arg)
}
next:
- lockmgr(&nfskevq_lock, LK_EXCLUSIVE, NULL);
+ rw_enter_write(&nfskevq_lock);
ke->flags &= ~KEVQ_BUSY;
if (ke->flags & KEVQ_WANT) {
ke->flags &= ~KEVQ_WANT;
@@ -175,10 +170,10 @@ next:
if (SLIST_EMPTY(&kevlist)) {
/* Nothing more to watch, exit */
pnfskq = NULL;
- lockmgr(&nfskevq_lock, LK_RELEASE, NULL);
+ rw_exit_write(&nfskevq_lock);
kthread_exit(0);
}
- lockmgr(&nfskevq_lock, LK_RELEASE, NULL);
+ rw_exit_write(&nfskevq_lock);
/* wait a while before checking for changes again */
tsleep(pnfskq, PSOCK, "nfskqpw",
@@ -204,14 +199,14 @@ filt_nfsdetach(struct knote *kn)
simple_unlock(&vp->v_selectinfo.vsi_lock);
/* Remove the vnode from watch list */
- lockmgr(&nfskevq_lock, LK_EXCLUSIVE, NULL);
+ rw_enter_write(&nfskevq_lock);
SLIST_FOREACH(ke, &kevlist, kev_link) {
if (ke->vp == vp) {
while (ke->flags & KEVQ_BUSY) {
ke->flags |= KEVQ_WANT;
- lockmgr(&nfskevq_lock, LK_RELEASE, NULL);
+ rw_exit_write(&nfskevq_lock);
(void) tsleep(ke, PSOCK, "nfskqdet", 0);
- lockmgr(&nfskevq_lock, LK_EXCLUSIVE, NULL);
+ rw_enter_write(&nfskevq_lock);
}
if (ke->usecount > 1) {
@@ -225,7 +220,7 @@ filt_nfsdetach(struct knote *kn)
break;
}
}
- lockmgr(&nfskevq_lock, LK_RELEASE, NULL);
+ rw_exit_write(&nfskevq_lock);
}
static int
@@ -316,7 +311,7 @@ nfs_kqfilter(void *v)
memset(&attr, 0, sizeof(attr));
(void) VOP_GETATTR(vp, &attr, p->p_ucred, p);
- lockmgr(&nfskevq_lock, LK_EXCLUSIVE, NULL);
+ rw_enter_write(&nfskevq_lock);
/* ensure the poller is running */
if (!pnfskq) {
@@ -358,8 +353,7 @@ nfs_kqfilter(void *v)
SLIST_INSERT_HEAD(&vp->v_klist, kn, kn_selnext);
#endif
- out:
- lockmgr(&nfskevq_lock, LK_RELEASE, NULL);
-
+out:
+ rw_exit_write(&nfskevq_lock);
return (error);
}
diff --git a/sys/nfs/nfs_subs.c b/sys/nfs/nfs_subs.c
index 7585b97a8da..ae497c69a62 100644
--- a/sys/nfs/nfs_subs.c
+++ b/sys/nfs/nfs_subs.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: nfs_subs.c,v 1.60 2007/04/13 10:01:35 thib Exp $ */
+/* $OpenBSD: nfs_subs.c,v 1.61 2007/04/19 14:46:44 thib Exp $ */
/* $NetBSD: nfs_subs.c,v 1.27.4.3 1996/07/08 20:34:24 jtc Exp $ */
/*
@@ -1070,10 +1070,6 @@ nfs_init()
timeout_set(&nfs_timer_to, nfs_timer, &nfs_timer_to);
nfs_timer(&nfs_timer_to);
-
-#ifdef NFSCLIENT
- nfs_kqinit();
-#endif
}
#ifdef NFSCLIENT
diff --git a/sys/nfs/nfs_var.h b/sys/nfs/nfs_var.h
index 5e2e85b3d49..9680562d095 100644
--- a/sys/nfs/nfs_var.h
+++ b/sys/nfs/nfs_var.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: nfs_var.h,v 1.25 2007/04/13 17:09:22 thib Exp $ */
+/* $OpenBSD: nfs_var.h,v 1.26 2007/04/19 14:46:44 thib Exp $ */
/* $NetBSD: nfs_var.h,v 1.3 1996/02/18 11:53:54 fvdl Exp $ */
/*
@@ -286,5 +286,4 @@ int nfs_savenickauth(struct nfsmount *, struct ucred *, int, NFSKERBKEY_T,
/* nfs_kq.c */
int nfs_kqfilter(void *);
-void nfs_kqinit(void);