svn commit: r309530 - in stable/10/sys: fs/nfsclient fs/nullfs sys
Konstantin Belousov
kib at FreeBSD.org
Sun Dec 4 13:56:17 UTC 2016
Author: kib
Date: Sun Dec 4 13:56:15 2016
New Revision: 309530
URL: https://svnweb.freebsd.org/changeset/base/309530
Log:
MFC r309209:
Do not enable nullfs vnode caching over nfs v4 mounts.
Modified:
stable/10/sys/fs/nfsclient/nfs_clvfsops.c
stable/10/sys/fs/nullfs/null_vfsops.c
stable/10/sys/sys/mount.h
Directory Properties:
stable/10/ (props changed)
Modified: stable/10/sys/fs/nfsclient/nfs_clvfsops.c
==============================================================================
--- stable/10/sys/fs/nfsclient/nfs_clvfsops.c Sun Dec 4 13:53:06 2016 (r309529)
+++ stable/10/sys/fs/nfsclient/nfs_clvfsops.c Sun Dec 4 13:56:15 2016 (r309530)
@@ -1201,6 +1201,8 @@ out:
MNT_ILOCK(mp);
mp->mnt_kern_flag |= MNTK_LOOKUP_SHARED | MNTK_NO_IOPF |
MNTK_USES_BCACHE;
+ if ((VFSTONFS(mp)->nm_flag & NFSMNT_NFSV4) != 0)
+ mp->mnt_kern_flag |= MNTK_NULL_NOCACHE;
MNT_IUNLOCK(mp);
}
return (error);
Modified: stable/10/sys/fs/nullfs/null_vfsops.c
==============================================================================
--- stable/10/sys/fs/nullfs/null_vfsops.c Sun Dec 4 13:53:06 2016 (r309529)
+++ stable/10/sys/fs/nullfs/null_vfsops.c Sun Dec 4 13:56:15 2016 (r309530)
@@ -188,7 +188,8 @@ nullfs_mount(struct mount *mp)
}
xmp->nullm_flags |= NULLM_CACHE;
- if (vfs_getopt(mp->mnt_optnew, "nocache", NULL, NULL) == 0)
+ if (vfs_getopt(mp->mnt_optnew, "nocache", NULL, NULL) == 0 ||
+ (xmp->nullm_vfs->mnt_kern_flag & MNTK_NULL_NOCACHE) != 0)
xmp->nullm_flags &= ~NULLM_CACHE;
MNT_ILOCK(mp);
Modified: stable/10/sys/sys/mount.h
==============================================================================
--- stable/10/sys/sys/mount.h Sun Dec 4 13:53:06 2016 (r309529)
+++ stable/10/sys/sys/mount.h Sun Dec 4 13:56:15 2016 (r309530)
@@ -362,7 +362,8 @@ void __mnt_vnode_markerfree_act
#define MNTK_SUSPEND 0x08000000 /* request write suspension */
#define MNTK_SUSPEND2 0x04000000 /* block secondary writes */
#define MNTK_SUSPENDED 0x10000000 /* write operations are suspended */
-#define MNTK_UNUSED25 0x20000000 /* --available-- */
+#define MNTK_NULL_NOCACHE 0x20000000 /* auto disable cache for nullfs
+ mounts over this fs */
#define MNTK_LOOKUP_SHARED 0x40000000 /* FS supports shared lock lookups */
#define MNTK_NOKNOTE 0x80000000 /* Don't send KNOTEs from VOP hooks */
More information about the svn-src-stable
mailing list