diff options
Diffstat (limited to 'fs/configfs/mount.c')
| -rw-r--r-- | fs/configfs/mount.c | 56 | 
1 files changed, 27 insertions, 29 deletions
diff --git a/fs/configfs/mount.c b/fs/configfs/mount.c index 7d3607febe1..f6c28583339 100644 --- a/fs/configfs/mount.c +++ b/fs/configfs/mount.c @@ -37,8 +37,7 @@  /* Random magic number */  #define CONFIGFS_MAGIC 0x62656570 -struct vfsmount * configfs_mount = NULL; -struct super_block * configfs_sb = NULL; +static struct vfsmount *configfs_mount = NULL;  struct kmem_cache *configfs_dir_cachep;  static int configfs_mnt_count = 0; @@ -77,30 +76,29 @@ static int configfs_fill_super(struct super_block *sb, void *data, int silent)  	sb->s_magic = CONFIGFS_MAGIC;  	sb->s_op = &configfs_ops;  	sb->s_time_gran = 1; -	configfs_sb = sb;  	inode = configfs_new_inode(S_IFDIR | S_IRWXU | S_IRUGO | S_IXUGO, -				   &configfs_root); +				   &configfs_root, sb);  	if (inode) { -		inode->i_op = &configfs_dir_inode_operations; +		inode->i_op = &configfs_root_inode_operations;  		inode->i_fop = &configfs_dir_operations;  		/* directory inodes start off with i_nlink == 2 (for "." entry) */  		inc_nlink(inode);  	} else { -		pr_debug("configfs: could not get root inode\n"); +		pr_debug("could not get root inode\n");  		return -ENOMEM;  	} -	root = d_alloc_root(inode); +	root = d_make_root(inode);  	if (!root) {  		pr_debug("%s: could not get root dentry!\n",__func__); -		iput(inode);  		return -ENOMEM;  	}  	config_group_init(&configfs_root_group);  	configfs_root_group.cg_item.ci_dentry = root;  	root->d_fsdata = &configfs_root;  	sb->s_root = root; +	sb->s_d_op = &configfs_dentry_ops; /* the rest get that */  	return 0;  } @@ -116,11 +114,13 @@ static struct file_system_type configfs_fs_type = {  	.mount		= configfs_do_mount,  	.kill_sb	= kill_litter_super,  }; +MODULE_ALIAS_FS("configfs"); -int configfs_pin_fs(void) +struct dentry *configfs_pin_fs(void)  { -	return simple_pin_fs(&configfs_fs_type, &configfs_mount, +	int err = simple_pin_fs(&configfs_fs_type, &configfs_mount,  			     &configfs_mnt_count); +	return err ? ERR_PTR(err) : configfs_mount->mnt_root;  }  void configfs_release_fs(void) @@ -142,28 +142,26 @@ static int __init configfs_init(void)  		goto out;  	config_kobj = kobject_create_and_add("config", kernel_kobj); -	if (!config_kobj) { -		kmem_cache_destroy(configfs_dir_cachep); -		configfs_dir_cachep = NULL; -		goto out; -	} +	if (!config_kobj) +		goto out2; + +	err = configfs_inode_init(); +	if (err) +		goto out3;  	err = register_filesystem(&configfs_fs_type); -	if (err) { -		printk(KERN_ERR "configfs: Unable to register filesystem!\n"); -		kobject_put(config_kobj); -		kmem_cache_destroy(configfs_dir_cachep); -		configfs_dir_cachep = NULL; -		goto out; -	} +	if (err) +		goto out4; -	err = configfs_inode_init(); -	if (err) { -		unregister_filesystem(&configfs_fs_type); -		kobject_put(config_kobj); -		kmem_cache_destroy(configfs_dir_cachep); -		configfs_dir_cachep = NULL; -	} +	return 0; +out4: +	pr_err("Unable to register filesystem!\n"); +	configfs_inode_exit(); +out3: +	kobject_put(config_kobj); +out2: +	kmem_cache_destroy(configfs_dir_cachep); +	configfs_dir_cachep = NULL;  out:  	return err;  }  | 
