VFS : mount lock scalability for internal mounts
authorTim Chen <tim.c.chen@linux.intel.com>
Tue, 19 Jul 2011 16:32:38 +0000 (09:32 -0700)
committerAl Viro <viro@zeniv.linux.org.uk>
Sun, 24 Jul 2011 14:08:32 +0000 (10:08 -0400)
commit423e0ab086ad8b33626e45fa94ac7613146b7ffa
tree249c9337a02254fe5dbede7436f78dfcc1ec508f
parentbbd9d6f7fbb0305c9a592bf05a32e87eb364a4ff
VFS : mount lock scalability for internal mounts

For a number of file systems that don't have a mount point (e.g. sockfs
and pipefs), they are not marked as long term. Therefore in
mntput_no_expire, all locks in vfs_mount lock are taken instead of just
local cpu's lock to aggregate reference counts when we release
reference to file objects.  In fact, only local lock need to have been
taken to update ref counts as these file systems are in no danger of
going away until we are ready to unregister them.

The attached patch marks file systems using kern_mount without
mount point as long term.  The contentions of vfs_mount lock
is now eliminated.  Before un-registering such file system,
kern_unmount should be called to remove the long term flag and
make the mount point ready to be freed.

Signed-off-by: Tim Chen <tim.c.chen@linux.intel.com>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
drivers/mtd/mtdchar.c
fs/anon_inodes.c
fs/hugetlbfs/inode.c
fs/namespace.c
fs/pipe.c
include/linux/fs.h
security/selinux/selinuxfs.c