diff options
| author | Jeff Roberson <jeff@FreeBSD.org> | 2003-03-13 07:05:22 +0000 |
|---|---|---|
| committer | Jeff Roberson <jeff@FreeBSD.org> | 2003-03-13 07:05:22 +0000 |
| commit | c033bdc01341b08f11b7dc7eb8ad6e1c63e9a28d (patch) | |
| tree | 4b323f0ea455e4b6eaea4695b0ce5d8607d23d83 /sys/nfsserver | |
| parent | 619bddc702d7de3de4d606e2afc81804369d67e7 (diff) | |
Notes
Diffstat (limited to 'sys/nfsserver')
| -rw-r--r-- | sys/nfsserver/nfs_serv.c | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/sys/nfsserver/nfs_serv.c b/sys/nfsserver/nfs_serv.c index e35b4dcc42a3..5c8554e86cf4 100644 --- a/sys/nfsserver/nfs_serv.c +++ b/sys/nfsserver/nfs_serv.c @@ -3701,17 +3701,20 @@ nfsrv_commit(struct nfsrv_descript *nfsd, struct nfssvc_sock *slp, * should not be set if B_INVAL is set there could be * a race here since we haven't locked the buffer). */ - if ((bp = gbincore(vp, lblkno)) != NULL && - (bp->b_flags & (B_DELWRI|B_INVAL)) == B_DELWRI) { + if ((bp = gbincore(vp, lblkno)) != NULL) { if (BUF_LOCK(bp, LK_EXCLUSIVE | LK_SLEEPFAIL | LK_INTERLOCK, VI_MTX(vp)) == ENOLCK) { VI_LOCK(vp); continue; /* retry */ } - bremfree(bp); - bp->b_flags &= ~B_ASYNC; - BUF_WRITE(bp); - ++nfs_commit_miss; + if ((bp->b_flags & (B_DELWRI|B_INVAL)) == + B_DELWRI) { + bremfree(bp); + bp->b_flags &= ~B_ASYNC; + BUF_WRITE(bp); + ++nfs_commit_miss; + } else + BUF_UNLOCK(bp); VI_LOCK(vp); } ++nfs_commit_blks; |
