Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp3479935imm; Tue, 29 May 2018 07:59:23 -0700 (PDT) X-Google-Smtp-Source: AB8JxZoOlZSXL1Qt+NMymMUOMC9QLg07dhfBbgW+w3ZQNnLamav0sm/gTH6HAtw9kLnqN8NZhtcf X-Received: by 2002:a62:fb14:: with SMTP id x20-v6mr17741295pfm.48.1527605963545; Tue, 29 May 2018 07:59:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527605963; cv=none; d=google.com; s=arc-20160816; b=V4hM73E+eHOdBA5p3oCmri26KgndhRWxR+3Uh4SWQBO9ufyhlRCdRrIdIS7ulNXl6A n6pjHYo2Bw//hREIgrZRt8bmkOueXSZpYkiD8GbLEIOSFahGn4BzCmNlHN4uu4QJylw9 2FdeUvFmFEhpWPXrUPkjJAB2sU02yNRqA60PebVWw2eIeGBnPWUKlt0gEsdufrl1d5xg LJUSdsekDE2hfQQn6PBQaOLOPh8jFg4Y1GS+JJs5sTyOJypaJa/zJKctqgKGwlgYnQO4 WKXn59IzGhHHWfmOqJZGSIWA8P6m+QQSasIxoj2lVlNjNhK7sxRadkIRoXwIO6JOY7xN t6GQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=+fVAsYkl2Vpdmeraq35IS0ndHsPAcxfRbQSIuX+KhJU=; b=u/hr9yC9RkyxzoAeEmiox1T/QBr1DbBnLSWgRQd9CBbYd5veUtvBqYmKYQguQEcyC8 9PyqiPlwKOvuu1qzTKKOwQdxZ51AWQ9Wuf/PQ/p/Ps4li+U4+k4Yl2+7cPn3iaZcpmsn 4dNcXwj+xNpbDHwKphARVs4YXz70X2cNLphi66MVRbT//rZskWV9NNr8R8+K2K1PlmKn Tp0PPYK8ayGk+QhjoT/IEN2eFSwXkA5nKBDvd68g8moo9CdDE5n0EwIRPmxAhnbe4ifM u7QR2TXQ8SiPmHAegcno/T7xjuignZKQ/Ic27mVsgitcit7rrpfmq1ay6x62SwK4M/ag UzRA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a95-v6si3448367pla.401.2018.05.29.07.59.09; Tue, 29 May 2018 07:59:23 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S936541AbeE2OqX (ORCPT + 99 others); Tue, 29 May 2018 10:46:23 -0400 Received: from mail-wm0-f54.google.com ([74.125.82.54]:54527 "EHLO mail-wm0-f54.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S935652AbeE2OqS (ORCPT ); Tue, 29 May 2018 10:46:18 -0400 Received: by mail-wm0-f54.google.com with SMTP id f6-v6so41370789wmc.4 for ; Tue, 29 May 2018 07:46:17 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=+fVAsYkl2Vpdmeraq35IS0ndHsPAcxfRbQSIuX+KhJU=; b=LTIEvkQjhzLUsPK1QvE+NqaPDpmohnqmj7AioI2pnNxPgI8rA1yUNV8NiMtWcA+RIs gmvDOtkP5Zc/MRylGlgpCaRuWd9xN1JQuzG7Gcue5u2s11w8kDxe7kqrVGYT322e8Wiq vadkZK8n2xsRcbUBY1U1ItxZcw7Xq0/8x2B+vXYEu8rVTXOQjgA1SANv+4rKigkFVreA 1Vk8xU5Tr4czmiy9HQIyiu1Eiu5qNtGs1DmWOyGcEEaGyazZcPGCNNUdDxUctWLCXRff uebNeTH7EVMwxVdfrTCu2lIVxlmIMwnHkMzHZof6nI+6s7T34KTAzhzKaqd9aSjLrkXz 4hCA== X-Gm-Message-State: ALKqPwfWKRNuozMC/xjh307vXhkXZUubdFDFdfNYlOvazjdMlMIBEbi3 qjDiFONPN+5n4bJrKO2f9JeVpA== X-Received: by 2002:a1c:7192:: with SMTP id d18-v6mr9155969wmi.115.1527605176853; Tue, 29 May 2018 07:46:16 -0700 (PDT) Received: from veci.piliscsaba.redhat.com (catv-176-63-54-97.catv.broadband.hu. [176.63.54.97]) by smtp.gmail.com with ESMTPSA id n71-v6sm20942227wmi.14.2018.05.29.07.46.15 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Tue, 29 May 2018 07:46:16 -0700 (PDT) From: Miklos Szeredi To: linux-unionfs@vger.kernel.org Cc: linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH 02/28] ovl: Move the copy up helpers to copy_up.c Date: Tue, 29 May 2018 16:45:46 +0200 Message-Id: <20180529144612.16675-3-mszeredi@redhat.com> X-Mailer: git-send-email 2.14.3 In-Reply-To: <20180529144612.16675-1-mszeredi@redhat.com> References: <20180529144612.16675-1-mszeredi@redhat.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Vivek Goyal Right now two copy up helpers are in inode.c. Amir suggested it might be better to move these to copy_up.c. There will one more related function which will come in later patch. Signed-off-by: Vivek Goyal Reviewed-by: Amir Goldstein Signed-off-by: Miklos Szeredi --- fs/overlayfs/copy_up.c | 32 ++++++++++++++++++++++++++++++++ fs/overlayfs/inode.c | 32 -------------------------------- fs/overlayfs/overlayfs.h | 2 +- 3 files changed, 33 insertions(+), 33 deletions(-) diff --git a/fs/overlayfs/copy_up.c b/fs/overlayfs/copy_up.c index e675e8349e71..91b3b668482b 100644 --- a/fs/overlayfs/copy_up.c +++ b/fs/overlayfs/copy_up.c @@ -779,6 +779,38 @@ int ovl_copy_up_flags(struct dentry *dentry, int flags) return err; } +static bool ovl_open_need_copy_up(struct dentry *dentry, int flags) +{ + /* Copy up of disconnected dentry does not set upper alias */ + if (ovl_dentry_upper(dentry) && + (ovl_dentry_has_upper_alias(dentry) || + (dentry->d_flags & DCACHE_DISCONNECTED))) + return false; + + if (special_file(d_inode(dentry)->i_mode)) + return false; + + if (!(OPEN_FMODE(flags) & FMODE_WRITE) && !(flags & O_TRUNC)) + return false; + + return true; +} + +int ovl_open_maybe_copy_up(struct dentry *dentry, unsigned int file_flags) +{ + int err = 0; + + if (ovl_open_need_copy_up(dentry, file_flags)) { + err = ovl_want_write(dentry); + if (!err) { + err = ovl_copy_up_flags(dentry, file_flags); + ovl_drop_write(dentry); + } + } + + return err; +} + int ovl_copy_up(struct dentry *dentry) { return ovl_copy_up_flags(dentry, 0); diff --git a/fs/overlayfs/inode.c b/fs/overlayfs/inode.c index c365b94fa158..60c88a09a3f3 100644 --- a/fs/overlayfs/inode.c +++ b/fs/overlayfs/inode.c @@ -399,38 +399,6 @@ struct posix_acl *ovl_get_acl(struct inode *inode, int type) return acl; } -static bool ovl_open_need_copy_up(struct dentry *dentry, int flags) -{ - /* Copy up of disconnected dentry does not set upper alias */ - if (ovl_dentry_upper(dentry) && - (ovl_dentry_has_upper_alias(dentry) || - (dentry->d_flags & DCACHE_DISCONNECTED))) - return false; - - if (special_file(d_inode(dentry)->i_mode)) - return false; - - if (!(OPEN_FMODE(flags) & FMODE_WRITE) && !(flags & O_TRUNC)) - return false; - - return true; -} - -int ovl_open_maybe_copy_up(struct dentry *dentry, unsigned int file_flags) -{ - int err = 0; - - if (ovl_open_need_copy_up(dentry, file_flags)) { - err = ovl_want_write(dentry); - if (!err) { - err = ovl_copy_up_flags(dentry, file_flags); - ovl_drop_write(dentry); - } - } - - return err; -} - int ovl_update_time(struct inode *inode, struct timespec *ts, int flags) { if (flags & S_ATIME) { diff --git a/fs/overlayfs/overlayfs.h b/fs/overlayfs/overlayfs.h index 1948e38c3c95..9172d3d5d870 100644 --- a/fs/overlayfs/overlayfs.h +++ b/fs/overlayfs/overlayfs.h @@ -332,7 +332,6 @@ int ovl_xattr_get(struct dentry *dentry, struct inode *inode, const char *name, void *value, size_t size); ssize_t ovl_listxattr(struct dentry *dentry, char *list, size_t size); struct posix_acl *ovl_get_acl(struct inode *inode, int type); -int ovl_open_maybe_copy_up(struct dentry *dentry, unsigned int file_flags); int ovl_update_time(struct inode *inode, struct timespec *ts, int flags); bool ovl_is_private_xattr(const char *name); @@ -391,6 +390,7 @@ extern const struct file_operations ovl_file_operations; /* copy_up.c */ int ovl_copy_up(struct dentry *dentry); int ovl_copy_up_flags(struct dentry *dentry, int flags); +int ovl_open_maybe_copy_up(struct dentry *dentry, unsigned int file_flags); int ovl_copy_xattr(struct dentry *old, struct dentry *new); int ovl_set_attr(struct dentry *upper, struct kstat *stat); struct ovl_fh *ovl_encode_real_fh(struct dentry *real, bool is_upper); -- 2.14.3