Commit e6dbcafb authored by Cyrill Gorcunov's avatar Cyrill Gorcunov Committed by Linus Torvalds

fs, fanotify: add @mflags field to fanotify output

The kernel keeps FAN_MARK_IGNORED_SURV_MODIFY bit separately from
fsnotify_mark::mask|ignored_mask thus put it in @mflags (mark flags)
field so the user-space reader will be able to detect if such bit were
used on mark creation procedure.

 | pos:	0
 | flags:	04002
 | fanotify flags:10 event-flags:0
 | fanotify mnt_id:12 mflags:40 mask:38 ignored_mask:40000003
 | fanotify ino:4f969 sdev:800013 mflags:0 mask:3b ignored_mask:40000000 fhandle-bytes:8 fhandle-type:1 f_handle:69f90400c275b5b4
Signed-off-by: default avatarCyrill Gorcunov <gorcunov@openvz.org>
Cc: Pavel Emelyanov <xemul@parallels.com>
Cc: Oleg Nesterov <oleg@redhat.com>
Cc: Andrey Vagin <avagin@openvz.org>
Cc: Al Viro <viro@ZenIV.linux.org.uk>
Cc: Alexey Dobriyan <adobriyan@gmail.com>
Cc: James Bottomley <jbottomley@parallels.com>
Cc: "Aneesh Kumar K.V" <aneesh.kumar@linux.vnet.ibm.com>
Cc: Matthew Helsley <matt.helsley@gmail.com>
Cc: "J. Bruce Fields" <bfields@fieldses.org>
Cc: Tvrtko Ursulin <tvrtko.ursulin@onelan.co.uk>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent f1d8c162
...@@ -111,29 +111,33 @@ int inotify_show_fdinfo(struct seq_file *m, struct file *f) ...@@ -111,29 +111,33 @@ int inotify_show_fdinfo(struct seq_file *m, struct file *f)
static int fanotify_fdinfo(struct seq_file *m, struct fsnotify_mark *mark) static int fanotify_fdinfo(struct seq_file *m, struct fsnotify_mark *mark)
{ {
unsigned int mflags = 0;
struct inode *inode; struct inode *inode;
int ret = 0; int ret = 0;
if (!(mark->flags & FSNOTIFY_MARK_FLAG_ALIVE)) if (!(mark->flags & FSNOTIFY_MARK_FLAG_ALIVE))
return 0; return 0;
if (mark->flags & FSNOTIFY_MARK_FLAG_IGNORED_SURV_MODIFY)
mflags |= FAN_MARK_IGNORED_SURV_MODIFY;
if (mark->flags & FSNOTIFY_MARK_FLAG_INODE) { if (mark->flags & FSNOTIFY_MARK_FLAG_INODE) {
inode = igrab(mark->i.inode); inode = igrab(mark->i.inode);
if (!inode) if (!inode)
goto out; goto out;
ret = seq_printf(m, "fanotify ino:%lx sdev:%x " ret = seq_printf(m, "fanotify ino:%lx sdev:%x "
"mask:%x ignored_mask:%x ", "mflags:%x mask:%x ignored_mask:%x ",
inode->i_ino, inode->i_sb->s_dev, inode->i_ino, inode->i_sb->s_dev,
mark->mask, mark->ignored_mask); mflags, mark->mask, mark->ignored_mask);
ret |= show_mark_fhandle(m, inode); ret |= show_mark_fhandle(m, inode);
ret |= seq_putc(m, '\n'); ret |= seq_putc(m, '\n');
iput(inode); iput(inode);
} else if (mark->flags & FSNOTIFY_MARK_FLAG_VFSMOUNT) { } else if (mark->flags & FSNOTIFY_MARK_FLAG_VFSMOUNT) {
struct mount *mnt = real_mount(mark->m.mnt); struct mount *mnt = real_mount(mark->m.mnt);
ret = seq_printf(m, "fanotify mnt_id:%x mask:%x " ret = seq_printf(m, "fanotify mnt_id:%x mflags:%x mask:%x "
"ignored_mask:%x\n", "ignored_mask:%x\n", mnt->mnt_id, mflags,
mnt->mnt_id, mark->mask, mark->ignored_mask); mark->mask, mark->ignored_mask);
} }
out: out:
return ret; return ret;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment