From: Amir Goldstein Date: Mon, 24 Apr 2017 19:26:40 +0000 (+0300) Subject: ovl: do not set overlay.opaque on non-dir create X-Git-Tag: v4.10.17~23 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=586aa5a6537f0f5f67487ec3f535488e77bbba82;p=thirdparty%2Fkernel%2Fstable.git ovl: do not set overlay.opaque on non-dir create 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 Signed-off-by: Miklos Szeredi Signed-off-by: Greg Kroah-Hartman --- diff --git a/fs/overlayfs/dir.c b/fs/overlayfs/dir.c index 16e06dd894575..2e1f16d22c16c 100644 --- a/fs/overlayfs/dir.c +++ b/fs/overlayfs/dir.c @@ -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); }