summaryrefslogtreecommitdiff
path: root/sys/nfsclient/nfs_socket.c
diff options
context:
space:
mode:
authorRobert Watson <rwatson@FreeBSD.org>2004-07-06 16:55:41 +0000
committerRobert Watson <rwatson@FreeBSD.org>2004-07-06 16:55:41 +0000
commitcf813ab24432c6b8a5597c5ee8b73d57c11cadf9 (patch)
treee7f8335dd5bbd0d5180e081cd497abd82a7406d0 /sys/nfsclient/nfs_socket.c
parente943975c69b69cc6bd95cb056704dcd68208f84b (diff)
Notes
Diffstat (limited to 'sys/nfsclient/nfs_socket.c')
-rw-r--r--sys/nfsclient/nfs_socket.c12
1 files changed, 6 insertions, 6 deletions
diff --git a/sys/nfsclient/nfs_socket.c b/sys/nfsclient/nfs_socket.c
index 43a6f7ed9541..f602e42658e0 100644
--- a/sys/nfsclient/nfs_socket.c
+++ b/sys/nfsclient/nfs_socket.c
@@ -156,7 +156,7 @@ int
nfs_connect(struct nfsmount *nmp, struct nfsreq *rep)
{
struct socket *so;
- int s, error, rcvreserve, sndreserve;
+ int error, rcvreserve, sndreserve;
int pktscale;
struct sockaddr *saddr;
struct thread *td = &thread0; /* only used for socreate and sobind */
@@ -241,25 +241,25 @@ nfs_connect(struct nfsmount *nmp, struct nfsreq *rep)
* connect system call but with the wait timing out so
* that interruptible mounts don't hang here for a long time.
*/
- s = splnet();
+ SOCK_LOCK(so);
while ((so->so_state & SS_ISCONNECTING) && so->so_error == 0) {
- (void) tsleep(&so->so_timeo,
+ (void) msleep(&so->so_timeo, SOCK_MTX(so),
PSOCK, "nfscon", 2 * hz);
if ((so->so_state & SS_ISCONNECTING) &&
so->so_error == 0 && rep &&
(error = nfs_sigintr(nmp, rep, rep->r_td)) != 0) {
so->so_state &= ~SS_ISCONNECTING;
- splx(s);
+ SOCK_UNLOCK(so);
goto bad;
}
}
if (so->so_error) {
error = so->so_error;
so->so_error = 0;
- splx(s);
+ SOCK_UNLOCK(so);
goto bad;
}
- splx(s);
+ SOCK_UNLOCK(so);
}
so->so_rcv.sb_timeo = 5 * hz;
so->so_snd.sb_timeo = 5 * hz;