Merge tag 'usercopy-v4.8' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux
[cascardo/linux.git] / fs / overlayfs / inode.c
index f7caf16..1b885c1 100644 (file)
@@ -137,8 +137,11 @@ int ovl_permission(struct inode *inode, int mask)
                return err;
 
        old_cred = ovl_override_creds(inode->i_sb);
-       if (!is_upper)
+       if (!is_upper && !special_file(realinode->i_mode) && mask & MAY_WRITE) {
                mask &= ~(MAY_WRITE | MAY_APPEND);
+               /* Make sure mounter can read file for copy up later */
+               mask |= MAY_READ;
+       }
        err = inode_permission(realinode, mask);
        revert_creds(old_cred);