diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-03-21 13:36:41 -0700 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-03-21 13:36:41 -0700 | 
| commit | e2a0883e4071237d09b604a342c28b96b44a04b3 (patch) | |
| tree | aa56f4d376b5eb1c32358c19c2669c2a94e0e1fd /fs/configfs/mount.c | |
| parent | 3a990a52f9f25f45469e272017a31e7a3fda60ed (diff) | |
| parent | 07c0c5d8b8c122b2f2df9ee574ac3083daefc981 (diff) | |
| download | olio-linux-3.10-e2a0883e4071237d09b604a342c28b96b44a04b3.tar.xz olio-linux-3.10-e2a0883e4071237d09b604a342c28b96b44a04b3.zip  | |
Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs
Pull vfs pile 1 from Al Viro:
 "This is _not_ all; in particular, Miklos' and Jan's stuff is not there
  yet."
* 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs: (64 commits)
  ext4: initialization of ext4_li_mtx needs to be done earlier
  debugfs-related mode_t whack-a-mole
  hfsplus: add an ioctl to bless files
  hfsplus: change finder_info to u32
  hfsplus: initialise userflags
  qnx4: new helper - try_extent()
  qnx4: get rid of qnx4_bread/qnx4_getblk
  take removal of PF_FORKNOEXEC to flush_old_exec()
  trim includes in inode.c
  um: uml_dup_mmap() relies on ->mmap_sem being held, but activate_mm() doesn't hold it
  um: embed ->stub_pages[] into mmu_context
  gadgetfs: list_for_each_safe() misuse
  ocfs2: fix leaks on failure exits in module_init
  ecryptfs: make register_filesystem() the last potential failure exit
  ntfs: forgets to unregister sysctls on register_filesystem() failure
  logfs: missing cleanup on register_filesystem() failure
  jfs: mising cleanup on register_filesystem() failure
  make configfs_pin_fs() return root dentry on success
  configfs: configfs_create_dir() has parent dentry in dentry->d_parent
  configfs: sanitize configfs_create()
  ...
Diffstat (limited to 'fs/configfs/mount.c')
| -rw-r--r-- | fs/configfs/mount.c | 16 | 
1 files changed, 7 insertions, 9 deletions
diff --git a/fs/configfs/mount.c b/fs/configfs/mount.c index 276e15cafd5..aee0a7ebbd8 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,12 +76,11 @@ 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); @@ -91,10 +89,9 @@ static int configfs_fill_super(struct super_block *sb, void *data, int silent)  		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); @@ -118,10 +115,11 @@ static struct file_system_type configfs_fs_type = {  	.kill_sb	= kill_litter_super,  }; -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)  |