diff --git a/sys/nfsclient/nfs_lock.c b/sys/nfsclient/nfs_lock.c index ee028dc33502..67f049abb5b0 100644 --- a/sys/nfsclient/nfs_lock.c +++ b/sys/nfsclient/nfs_lock.c @@ -60,12 +60,6 @@ __FBSDID("$FreeBSD$"); #include #include -#define NFSOWNER_1ST_LEVEL_START 1 /* initial entries */ -#define NFSOWNER_2ND_LEVEL 256 /* some power of 2 */ - -#define NFSOWNER(tbl, i) \ - (tbl)[(i) / NFSOWNER_2ND_LEVEL][(i) % NFSOWNER_2ND_LEVEL] - /* * XXX * We have to let the process know if the call succeeded. I'm using an extra @@ -129,11 +123,6 @@ nfs_dolock(struct vop_advlock_args *ap) msg.lm_fl = *fl; msg.lm_wait = ap->a_flags & F_WAIT; msg.lm_getlk = ap->a_op == F_GETLK; - /* - * XXX: the lm_cred assignment below directly exports a ucred - * structure to userland. This is probably wrong, and should at - * least be xucred. - */ bcopy(VFSTONFS(vp->v_mount)->nm_nam, &msg.lm_addr, min(sizeof msg.lm_addr, VFSTONFS(vp->v_mount)->nm_nam->sa_len)); msg.lm_fh_len = NFS_ISV3(vp) ? VTONFS(vp)->n_fhsize : NFSX_V2FH; @@ -192,8 +181,8 @@ nfs_dolock(struct vop_advlock_args *ap) * on a local network). XXX Probably should use a back-off * scheme. */ - if ((error = tsleep((void *)p->p_nlminfo, - PCATCH | PUSER, "lockd", 20*hz)) != 0) { + error = tsleep(p->p_nlminfo, PCATCH | PUSER, "lockd", 20*hz); + if (error != 0) { if (error == EWOULDBLOCK) { /* * We timed out, so we rewrite the request @@ -218,10 +207,9 @@ nfs_dolock(struct vop_advlock_args *ap) break; } - if ((error1 = vn_close(wvp, FWRITE, thread0.td_ucred, td)) && error == 0) - return (error1); - - return (error); + error1 = vn_close(wvp, FWRITE, thread0.td_ucred, td); + /* prefer any previous 'error' to our vn_close 'error1'. */ + return (error != 0 ? error : error1); } /* @@ -270,7 +258,7 @@ nfslockdans(struct thread *td, struct lockd_ans *ansp) targetp->p_nlminfo->set_getlk_pid = ansp->la_set_getlk_pid; targetp->p_nlminfo->getlk_pid = ansp->la_getlk_pid; - (void)wakeup((void *)targetp->p_nlminfo); + wakeup(targetp->p_nlminfo); PROC_UNLOCK(targetp); return (0);