From owner-freebsd-bugs Thu Apr 17 19:30:11 1997 Return-Path: Received: (from root@localhost) by freefall.freebsd.org (8.8.5/8.8.5) id TAA25684 for bugs-outgoing; Thu, 17 Apr 1997 19:30:11 -0700 (PDT) Received: (from gnats@localhost) by freefall.freebsd.org (8.8.5/8.8.5) id TAA25674; Thu, 17 Apr 1997 19:30:04 -0700 (PDT) Date: Thu, 17 Apr 1997 19:30:04 -0700 (PDT) Message-Id: <199704180230.TAA25674@freefall.freebsd.org> To: freebsd-bugs Cc: From: Thomas David Rivers Subject: Re: kern/3304: NFS V2 readdir hangs Reply-To: Thomas David Rivers Sender: owner-bugs@FreeBSD.ORG X-Loop: FreeBSD.org Precedence: bulk The following reply was made to PR kern/3304; it has been noted by GNATS. From: Thomas David Rivers To: ponds!lakes.water.net!rivers, ponds!khavrinen.lcs.mit.edu!wollman Cc: ponds!freefall.freebsd.org!freebsd-gnats-submit Subject: Re: kern/3304: NFS V2 readdir hangs Date: Thu, 17 Apr 1997 21:12:42 -0400 (EDT) > Garrett writes: > > < said: > > > It appears that nfs_receive() calls soreceive() which calls sbwait() > > waiting on a UDP packet to be received.. That's fine. > > > Then, another nfs_request() is issued; calling nfs_receive() which > > winds down to sbwait() as well. > > > Then, the udp packet from the first call is received; we wake up the > > *second* caller and get everything out-of-sync. > > This is perfectly reasonable behavior for soreceive(). NFS is clearly > broken here. NFS needs its own response-demultiplexing layer, it > seems. > > -GAWollman > Well - yes; except in this instance there is a lock protecting the multiple soreceive()s, nfs_rcvlock(). I think the question is why didn't that protection work. [In fact, there's a comment in nfs_socket.c that indicates the rcvlock is used to protect from just this situation.] Apparently, since 2.1.5 runs on the same machine just fine; this used to work and has now been compromised.... [that's just a guess.] - Dave Rivers -