summaryrefslogtreecommitdiffstats
path: root/fs/overlayfs/super.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/overlayfs/super.c')
-rw-r--r--fs/overlayfs/super.c30
1 files changed, 14 insertions, 16 deletions
diff --git a/fs/overlayfs/super.c b/fs/overlayfs/super.c
index 5a5b41c542fb..c695ea569a99 100644
--- a/fs/overlayfs/super.c
+++ b/fs/overlayfs/super.c
@@ -1151,6 +1151,10 @@ static int ovl_fill_super(struct super_block *sb, void *data, int silent)
if (!ufs)
goto out;
+ ufs->creator_cred = cred = prepare_creds();
+ if (!cred)
+ goto out_err;
+
ufs->config.redirect_dir = ovl_redirect_dir_def;
ufs->config.index = ovl_index_def;
err = ovl_parse_opt((char *) data, &ufs->config);
@@ -1176,27 +1180,25 @@ static int ovl_fill_super(struct super_block *sb, void *data, int silent)
if (err)
goto out_err;
- err = ovl_get_workpath(ufs, &upperpath, &workpath);
+ err = ovl_get_upper(ufs, &upperpath);
if (err)
goto out_err;
- sb->s_stack_depth = upperpath.mnt->mnt_sb->s_stack_depth;
- }
- err = ovl_get_lowerstack(sb, ufs, &stack, &numlower);
- if (err)
- goto out_err;
-
- if (ufs->config.upperdir) {
- err = ovl_get_upper(ufs, &upperpath);
+ err = ovl_get_workpath(ufs, &upperpath, &workpath);
if (err)
goto out_err;
- sb->s_time_gran = ufs->upper_mnt->mnt_sb->s_time_gran;
-
err = ovl_get_workdir(sb, ufs, &workpath);
if (err)
goto out_err;
+
+ sb->s_stack_depth = ufs->upper_mnt->mnt_sb->s_stack_depth;
+ sb->s_time_gran = ufs->upper_mnt->mnt_sb->s_time_gran;
+
}
+ err = ovl_get_lowerstack(sb, ufs, &stack, &numlower);
+ if (err)
+ goto out_err;
err = ovl_get_lower_layers(ufs, stack, numlower);
if (err)
@@ -1228,11 +1230,6 @@ static int ovl_fill_super(struct super_block *sb, void *data, int silent)
if (!ufs->indexdir)
ufs->config.index = false;
- err = -ENOMEM;
- ufs->creator_cred = cred = prepare_creds();
- if (!cred)
- goto out_err;
-
/* Never override disk quota limits or use reserved space */
cap_lower(cred->cap_effective, CAP_SYS_RESOURCE);
@@ -1242,6 +1239,7 @@ static int ovl_fill_super(struct super_block *sb, void *data, int silent)
sb->s_fs_info = ufs;
sb->s_flags |= MS_POSIXACL | MS_NOREMOTELOCK;
+ err = -ENOMEM;
root_dentry = d_make_root(ovl_new_inode(sb, S_IFDIR, 0));
if (!root_dentry)
goto out_err;