svn commit: r214820 - stable/8/sys/fs/nfsclient
Rick Macklem
rmacklem at FreeBSD.org
Fri Nov 5 02:33:27 UTC 2010
Author: rmacklem
Date: Fri Nov 5 02:33:27 2010
New Revision: 214820
URL: http://svn.freebsd.org/changeset/base/214820
Log:
MFC: r214511
Add a call for nfsrpc_close() to ncl_reclaim() in the experimental
NFSv4 client, since the call in ncl_inactive() might be missed
because VOP_INACTIVE() is not guaranteed to be called before
VOP_RECLAIM().
Modified:
stable/8/sys/fs/nfsclient/nfs_clnode.c
Directory Properties:
stable/8/sys/ (props changed)
stable/8/sys/amd64/include/xen/ (props changed)
stable/8/sys/cddl/contrib/opensolaris/ (props changed)
stable/8/sys/contrib/dev/acpica/ (props changed)
stable/8/sys/contrib/pf/ (props changed)
stable/8/sys/dev/xen/xenpci/ (props changed)
Modified: stable/8/sys/fs/nfsclient/nfs_clnode.c
==============================================================================
--- stable/8/sys/fs/nfsclient/nfs_clnode.c Fri Nov 5 02:12:18 2010 (r214819)
+++ stable/8/sys/fs/nfsclient/nfs_clnode.c Fri Nov 5 02:33:27 2010 (r214820)
@@ -236,6 +236,15 @@ ncl_reclaim(struct vop_reclaim_args *ap)
if (prtactive && vrefcnt(vp) != 0)
vprint("ncl_reclaim: pushing active", vp);
+ if (NFS_ISV4(vp) && vp->v_type == VREG)
+ /*
+ * Since mmap()'d files do I/O after VOP_CLOSE(), the NFSv4
+ * Close operations are delayed until ncl_inactive().
+ * However, since VOP_INACTIVE() is not guaranteed to be
+ * called, we need to do it again here.
+ */
+ (void) nfsrpc_close(vp, 1, ap->a_td);
+
/*
* If the NLM is running, give it a chance to abort pending
* locks.
More information about the svn-src-stable
mailing list