The patch titled vfs: mountinfo show dominating group id has been added to the -mm tree. Its filename is vfs-mountinfo-show-dominating-group-id.patch Before you just go and hit "reply", please: a) Consider who else should be cc'ed b) Prefer to cc a suitable mailing list as well c) Ideally: find the original patch on the mailing list and do a reply-to-all to that, adding suitable additional cc's *** Remember to use Documentation/SubmitChecklist when testing your code *** See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find out what to do about this The current -mm tree may be found at http://userweb.kernel.org/~akpm/mmotm/ ------------------------------------------------------ Subject: vfs: mountinfo show dominating group id From: Miklos Szeredi <mszeredi@xxxxxxx> Show peer group ID of nearest dominating group that has intersection with the mount's namespace. See the the documentation update for details. Signed-off-by: Miklos Szeredi <mszeredi@xxxxxxx> Cc: Ram Pai <linuxram@xxxxxxxxxx> Cc: Al Viro <viro@xxxxxxxxxxxxxxxxxx> Cc: Christoph Hellwig <hch@xxxxxx> Cc: Dave Hansen <haveblue@xxxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> --- Documentation/filesystems/proc.txt | 11 ++++++--- fs/namespace.c | 24 +++++++++++++------- fs/pnode.c | 32 +++++++++++++++++++++++++++ fs/pnode.h | 1 4 files changed, 57 insertions(+), 11 deletions(-) diff -puN Documentation/filesystems/proc.txt~vfs-mountinfo-show-dominating-group-id Documentation/filesystems/proc.txt --- a/Documentation/filesystems/proc.txt~vfs-mountinfo-show-dominating-group-id +++ a/Documentation/filesystems/proc.txt @@ -2367,15 +2367,20 @@ MNTOPTS: per mount options SBOPTS: per super block options PROPAGATION: propagation type -propagation type: <propagation_flag>[:<peergrpid>][,...] +propagation type: <propagation_flag>[:<peergrpid>[:<domgrpid>]][,...] note: 'shared' flag is followed by the id of this mount's peer group - 'slave' flag is followed by the peer group id of its master mount + 'slave' flag is followed by the peer group id of its master mount, + optionally followed by the id of the closest dominant(*) + peer group in the same namespace, if one exists. 'private' flag stands by itself 'unbindable' flag stands by itself +(*) A dominant peer group is an ancestor of this mount in the +propagation tree, in other words, this mount receives propagation from +the dominant peer group, but not the other way round. + For more information see: Documentation/filesystems/sharedsubtree.txt - ------------------------------------------------------------------------------ diff -puN fs/namespace.c~vfs-mountinfo-show-dominating-group-id fs/namespace.c --- a/fs/namespace.c~vfs-mountinfo-show-dominating-group-id +++ a/fs/namespace.c @@ -809,16 +809,24 @@ static int show_mountinfo(struct seq_fil show_sb_opts(m, sb); if (sb->s_op->show_options) err = sb->s_op->show_options(m, mnt); - if (IS_MNT_SHARED(mnt)) { - seq_printf(m, " shared:%i", get_peer_group_id(mnt)); - if (IS_MNT_SLAVE(mnt)) - seq_printf(m, ",slave:%i", get_master_id(mnt)); - } else if (IS_MNT_SLAVE(mnt)) { - seq_printf(m, " slave:%i", get_master_id(mnt)); + seq_putc(m, ' '); + if (IS_MNT_SHARED(mnt) || IS_MNT_SLAVE(mnt)) { + if (IS_MNT_SHARED(mnt)) + seq_printf(m, "shared:%i", get_peer_group_id(mnt)); + if (IS_MNT_SLAVE(mnt)) { + int dominator_id = get_dominator_id_same_ns(mnt); + + if (IS_MNT_SHARED(mnt)) + seq_putc(m, ','); + + seq_printf(m, "slave:%i", get_master_id(mnt)); + if (dominator_id != -1) + seq_printf(m, ":%i", dominator_id); + } } else if (IS_MNT_UNBINDABLE(mnt)) { - seq_printf(m, " unbindable"); + seq_printf(m, "unbindable"); } else { - seq_printf(m, " private"); + seq_printf(m, "private"); } seq_putc(m, '\n'); return err; diff -puN fs/pnode.c~vfs-mountinfo-show-dominating-group-id fs/pnode.c --- a/fs/pnode.c~vfs-mountinfo-show-dominating-group-id +++ a/fs/pnode.c @@ -88,6 +88,38 @@ int get_master_id(struct vfsmount *mnt) return id; } +static struct vfsmount *get_peer_in_ns(struct vfsmount *mnt, + struct mnt_namespace *ns) +{ + struct vfsmount *m = mnt; + + do { + if (m->mnt_ns == ns) + return m; + m = next_peer(m); + } while (m != mnt); + + return NULL; +} + +int get_dominator_id_same_ns(struct vfsmount *mnt) +{ + int id = -1; + struct vfsmount *m; + + spin_lock(&vfsmount_lock); + for (m = mnt->mnt_master; m != NULL; m = m->mnt_master) { + struct vfsmount *d = get_peer_in_ns(m, mnt->mnt_ns); + if (d) { + id = d->mnt_pgid; + break; + } + } + spin_unlock(&vfsmount_lock); + + return id; +} + static int do_make_slave(struct vfsmount *mnt) { struct vfsmount *peer_mnt = mnt, *master = mnt->mnt_master; diff -puN fs/pnode.h~vfs-mountinfo-show-dominating-group-id fs/pnode.h --- a/fs/pnode.h~vfs-mountinfo-show-dominating-group-id +++ a/fs/pnode.h @@ -33,4 +33,5 @@ int propagate_umount(struct list_head *) int propagate_mount_busy(struct vfsmount *, int); int get_peer_group_id(struct vfsmount *); int get_master_id(struct vfsmount *); +int get_dominator_id_same_ns(struct vfsmount *); #endif /* _LINUX_PNODE_H */ _ Patches currently in -mm which might be from mszeredi@xxxxxxx are vfs-create-proc-pid-mountinfo.patch vfs-mountinfo-mm-fix.patch vfs-pnode-cleanup.patch vfs-mountinfo-stable-peer-group-id.patch vfs-mountinfo-show-dominating-group-id.patch vfs-optimization-to-proc-pid-mountinfo-patch.patch vfs-mountinfo-only-show-mounts-under-tasks-root.patch mm-bdi-export-bdi-attributes-in-sysfs.patch mm-bdi-export-bdi-attributes-in-sysfs-fix.patch mm-bdi-export-bdi-attributes-in-sysfs-fix-2.patch mm-bdi-export-bdi-attributes-in-sysfs-fix-3.patch mm-bdi-export-bdi-attributes-in-sysfs-fix-4.patch mm-bdi-export-bdi-attributes-in-sysfs-ia64-fix.patch mm-bdi-expose-the-bdi-object-in-sysfs-for-nfs.patch mm-bdi-expose-the-bdi-object-in-sysfs-for-nfs-fix.patch mm-bdi-expose-the-bdi-object-in-sysfs-for-fuse.patch mm-bdi-expose-the-bdi-object-in-sysfs-for-fuse-fix.patch mm-bdi-allow-setting-a-minimum-for-the-bdi-dirty-limit.patch mm-bdi-allow-setting-a-maximum-for-the-bdi-dirty-limit.patch mm-bdi-allow-setting-a-maximum-for-the-bdi-dirty-limit-fix.patch mm-bdi-move-statistics-to-debugfs.patch -- To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html