Catch filesystems lacking s_bdi
noop_backing_dev_info is used only as a flag to mark filesystems that don't have any backing store, like tmpfs, procfs, spufs, etc. Signed-off-by: Joern Engel <joern@logfs.org> Changed the BUG_ON() to a WARN_ON(). Note that adding dirty inodes to the noop_backing_dev_info is not legal and will not result in them being flushed, but we already catch this condition in __mark_inode_dirty() when checking for a registered bdi. Signed-off-by: Jens Axboe <jens.axboe@oracle.com>
This commit is contained in:
@@ -693,6 +693,7 @@ int set_anon_super(struct super_block *s, void *data)
|
||||
return -EMFILE;
|
||||
}
|
||||
s->s_dev = MKDEV(0, dev & MINORMASK);
|
||||
s->s_bdi = &noop_backing_dev_info;
|
||||
return 0;
|
||||
}
|
||||
|
||||
@@ -954,10 +955,11 @@ vfs_kern_mount(struct file_system_type *type, int flags, const char *name, void
|
||||
if (error < 0)
|
||||
goto out_free_secdata;
|
||||
BUG_ON(!mnt->mnt_sb);
|
||||
WARN_ON(!mnt->mnt_sb->s_bdi);
|
||||
|
||||
error = security_sb_kern_mount(mnt->mnt_sb, flags, secdata);
|
||||
if (error)
|
||||
goto out_sb;
|
||||
error = security_sb_kern_mount(mnt->mnt_sb, flags, secdata);
|
||||
if (error)
|
||||
goto out_sb;
|
||||
|
||||
/*
|
||||
* filesystems should never set s_maxbytes larger than MAX_LFS_FILESIZE
|
||||
|
Reference in New Issue
Block a user