diff options
Diffstat (limited to 'fs/debugfs/inode.c')
| -rw-r--r-- | fs/debugfs/inode.c | 22 | 
1 files changed, 16 insertions, 6 deletions
| diff --git a/fs/debugfs/inode.c b/fs/debugfs/inode.c index a0357b0cf362..661a99a7dfbe 100644 --- a/fs/debugfs/inode.c +++ b/fs/debugfs/inode.c @@ -183,6 +183,9 @@ static int debugfs_reconfigure(struct fs_context *fc)  	struct debugfs_fs_info *sb_opts = sb->s_fs_info;  	struct debugfs_fs_info *new_opts = fc->s_fs_info; +	if (!new_opts) +		return 0; +  	sync_filesystem(sb);  	/* structure copy of new mount options to sb */ @@ -282,10 +285,16 @@ static int debugfs_fill_super(struct super_block *sb, struct fs_context *fc)  static int debugfs_get_tree(struct fs_context *fc)  { +	int err; +  	if (!(debugfs_allow & DEBUGFS_ALLOW_API))  		return -EPERM; -	return get_tree_single(fc, debugfs_fill_super); +	err = get_tree_single(fc, debugfs_fill_super); +	if (err) +		return err; + +	return debugfs_reconfigure(fc);  }  static void debugfs_free_fc(struct fs_context *fc) @@ -353,7 +362,8 @@ struct dentry *debugfs_lookup(const char *name, struct dentry *parent)  }  EXPORT_SYMBOL_GPL(debugfs_lookup); -static struct dentry *start_creating(const char *name, struct dentry *parent) +static struct dentry *debugfs_start_creating(const char *name, +					     struct dentry *parent)  {  	struct dentry *dentry;  	int error; @@ -419,7 +429,7 @@ static struct dentry *__debugfs_create_file(const char *name, umode_t mode,  	if (!(mode & S_IFMT))  		mode |= S_IFREG;  	BUG_ON(!S_ISREG(mode)); -	dentry = start_creating(name, parent); +	dentry = debugfs_start_creating(name, parent);  	if (IS_ERR(dentry))  		return dentry; @@ -568,7 +578,7 @@ EXPORT_SYMBOL_GPL(debugfs_create_file_size);   */  struct dentry *debugfs_create_dir(const char *name, struct dentry *parent)  { -	struct dentry *dentry = start_creating(name, parent); +	struct dentry *dentry = debugfs_start_creating(name, parent);  	struct inode *inode;  	if (IS_ERR(dentry)) @@ -615,7 +625,7 @@ struct dentry *debugfs_create_automount(const char *name,  					debugfs_automount_t f,  					void *data)  { -	struct dentry *dentry = start_creating(name, parent); +	struct dentry *dentry = debugfs_start_creating(name, parent);  	struct inode *inode;  	if (IS_ERR(dentry)) @@ -678,7 +688,7 @@ struct dentry *debugfs_create_symlink(const char *name, struct dentry *parent,  	if (!link)  		return ERR_PTR(-ENOMEM); -	dentry = start_creating(name, parent); +	dentry = debugfs_start_creating(name, parent);  	if (IS_ERR(dentry)) {  		kfree(link);  		return dentry; | 
