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/ecryptfs/main.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/ecryptfs/main.c')
| -rw-r--r-- | fs/ecryptfs/main.c | 19 | 
1 files changed, 9 insertions, 10 deletions
diff --git a/fs/ecryptfs/main.c b/fs/ecryptfs/main.c index b4a6befb121..68954937a07 100644 --- a/fs/ecryptfs/main.c +++ b/fs/ecryptfs/main.c @@ -550,9 +550,8 @@ static struct dentry *ecryptfs_mount(struct file_system_type *fs_type, int flags  	if (IS_ERR(inode))  		goto out_free; -	s->s_root = d_alloc_root(inode); +	s->s_root = d_make_root(inode);  	if (!s->s_root) { -		iput(inode);  		rc = -ENOMEM;  		goto out_free;  	} @@ -795,15 +794,10 @@ static int __init ecryptfs_init(void)  		       "Failed to allocate one or more kmem_cache objects\n");  		goto out;  	} -	rc = register_filesystem(&ecryptfs_fs_type); -	if (rc) { -		printk(KERN_ERR "Failed to register filesystem\n"); -		goto out_free_kmem_caches; -	}  	rc = do_sysfs_registration();  	if (rc) {  		printk(KERN_ERR "sysfs registration failed\n"); -		goto out_unregister_filesystem; +		goto out_free_kmem_caches;  	}  	rc = ecryptfs_init_kthread();  	if (rc) { @@ -824,19 +818,24 @@ static int __init ecryptfs_init(void)  		       "rc = [%d]\n", rc);  		goto out_release_messaging;  	} +	rc = register_filesystem(&ecryptfs_fs_type); +	if (rc) { +		printk(KERN_ERR "Failed to register filesystem\n"); +		goto out_destroy_crypto; +	}  	if (ecryptfs_verbosity > 0)  		printk(KERN_CRIT "eCryptfs verbosity set to %d. Secret values "  			"will be written to the syslog!\n", ecryptfs_verbosity);  	goto out; +out_destroy_crypto: +	ecryptfs_destroy_crypto();  out_release_messaging:  	ecryptfs_release_messaging();  out_destroy_kthread:  	ecryptfs_destroy_kthread();  out_do_sysfs_unregistration:  	do_sysfs_unregistration(); -out_unregister_filesystem: -	unregister_filesystem(&ecryptfs_fs_type);  out_free_kmem_caches:  	ecryptfs_free_kmem_caches();  out:  |