summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorThordur I. Bjornsson <thib@cvs.openbsd.org>2008-05-13 17:47:43 +0000
committerThordur I. Bjornsson <thib@cvs.openbsd.org>2008-05-13 17:47:43 +0000
commitd222a43d256da04a7dbe0a08d82ffbcfe7f17893 (patch)
tree6beafc9f2129cf38cf08c47190eb0e3f0d91d8b5 /sys
parent058c9ffd814b7610bedd175a46763ef16917794e (diff)
don't grab the receive lock in nfs_rcvlock if the reply has
already been received while we slept. prevents processes from monopolising the lock. From FreeBSD; ok blambert@ tested by johan@ and a few others
Diffstat (limited to 'sys')
-rw-r--r--sys/nfs/nfs_socket.c17
1 files changed, 10 insertions, 7 deletions
diff --git a/sys/nfs/nfs_socket.c b/sys/nfs/nfs_socket.c
index 7ea2ec2b45b..dc1d0d0441c 100644
--- a/sys/nfs/nfs_socket.c
+++ b/sys/nfs/nfs_socket.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: nfs_socket.c,v 1.57 2008/01/06 17:38:23 blambert Exp $ */
+/* $OpenBSD: nfs_socket.c,v 1.58 2008/05/13 17:47:42 thib Exp $ */
/* $NetBSD: nfs_socket.c,v 1.27 1996/04/15 20:20:00 thorpej Exp $ */
/*
@@ -681,12 +681,8 @@ nfs_reply(myrep)
*/
error = nfs_rcvlock(myrep);
if (error)
- return (error);
- /* Already received, bye bye */
- if (myrep->r_mrep != NULL) {
- nfs_rcvunlock(&nmp->nm_flag);
- return (0);
- }
+ return (error == EALREADY ? 0 : error);
+
/*
* Get the next Rpc reply off the socket
*/
@@ -1381,6 +1377,13 @@ nfs_rcvlock(rep)
*flagp |= NFSMNT_WANTRCV;
(void) tsleep((caddr_t)flagp, slpflag | (PZERO - 1), "nfsrcvlk",
slptimeo);
+ if (rep->r_mrep != NULL) {
+ /*
+ * Don't take the lock if our reply has been received
+ * while we where sleeping.
+ */
+ return (EALREADY);
+ }
if (slpflag == PCATCH) {
slpflag = 0;
slptimeo = 2 * hz;