diff options
author | Amir Goldstein <amir73il@gmail.com> | 2017-01-17 07:34:53 +0300 |
---|---|---|
committer | Miklos Szeredi <mszeredi@redhat.com> | 2017-02-07 17:47:14 +0300 |
commit | e7f52429b4a5b2e3224948d1737eb264c8f7e15f (patch) | |
tree | c3d1a5bec15caa0f01768772f9bc7334ff7dfd43 /fs/overlayfs/super.c | |
parent | bfe219d373cadab761373aeea4c70406bc27ea2c (diff) | |
download | linux-e7f52429b4a5b2e3224948d1737eb264c8f7e15f.tar.xz |
ovl: check if upperdir fs supports O_TMPFILE
This is needed for choosing between concurrent copyup
using O_TMPFILE and legacy copyup using workdir+rename.
Signed-off-by: Amir Goldstein <amir73il@gmail.com>
Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
Diffstat (limited to 'fs/overlayfs/super.c')
-rw-r--r-- | fs/overlayfs/super.c | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/fs/overlayfs/super.c b/fs/overlayfs/super.c index 20f48abbb82f..ff05065b510f 100644 --- a/fs/overlayfs/super.c +++ b/fs/overlayfs/super.c @@ -825,6 +825,8 @@ static int ovl_fill_super(struct super_block *sb, void *data, int silent) * creation of workdir in previous step. */ if (ufs->workdir) { + struct dentry *temp; + err = ovl_check_d_type_supported(&workpath); if (err < 0) goto out_put_workdir; @@ -836,6 +838,14 @@ static int ovl_fill_super(struct super_block *sb, void *data, int silent) */ if (!err) pr_warn("overlayfs: upper fs needs to support d_type.\n"); + + /* Check if upper/work fs supports O_TMPFILE */ + temp = ovl_do_tmpfile(ufs->workdir, S_IFREG | 0); + ufs->tmpfile = !IS_ERR(temp); + if (ufs->tmpfile) + dput(temp); + else + pr_warn("overlayfs: upper fs does not support tmpfile.\n"); } } |