]> git.proxmox.com Git - mirror_ubuntu-zesty-kernel.git/commitdiff
ovl: do not set overlay.opaque on non-dir create
authorAmir Goldstein <amir73il@gmail.com>
Mon, 24 Apr 2017 19:26:40 +0000 (22:26 +0300)
committerStefan Bader <stefan.bader@canonical.com>
Tue, 20 Jun 2017 08:50:44 +0000 (10:50 +0200)
BugLink: http://bugs.launchpad.net/bugs/1692898
commit 4a99f3c83dc493c8ea84693d78cd792839c8aa64 upstream.

The optimization for opaque dir create was wrongly being applied
also to non-dir create.

Fixes: 97c684cc9110 ("ovl: create directories inside merged parent opaque")
Signed-off-by: Amir Goldstein <amir73il@gmail.com>
Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Stefan Bader <stefan.bader@canonical.com>
Signed-off-by: Kleber Sacilotto de Souza <kleber.souza@canonical.com>
fs/overlayfs/dir.c

index 16e06dd894575900f0043f417c5bf6227b690cf9..2e1f16d22c16cd15067bb571e178876c13273c75 100644 (file)
@@ -209,7 +209,7 @@ static int ovl_create_upper(struct dentry *dentry, struct inode *inode,
        if (err)
                goto out_dput;
 
-       if (ovl_type_merge(dentry->d_parent)) {
+       if (ovl_type_merge(dentry->d_parent) && d_is_dir(newdentry)) {
                /* Setting opaque here is just an optimization, allow to fail */
                ovl_set_opaque(dentry, newdentry);
        }