Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp236483ybt; Tue, 30 Jun 2020 19:39:37 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyj3IHI8qzluPlsklyzJlTohISNE3ec+QH7/8Z9k7tniUGUzg5lyY/FUgStOsuEeNPrbLZu X-Received: by 2002:a17:906:915:: with SMTP id i21mr21187525ejd.313.1593571177743; Tue, 30 Jun 2020 19:39:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593571177; cv=none; d=google.com; s=arc-20160816; b=DybP4Rt5MQUzJkCLgMbdJ8D6sbkF6wSxlXW1dqHYkv7roFnInHetYJSEyRGF+gTDzu CfVy4vPOWrUr1Af/AIByFZZ+T52vYUZZYP3cFN2VF4N56HRaFQxkCA46RQzKuuyOTkOe vmxNO5JSk0jTQPAiRmjm7O9XTm947qCi1VTCM+e/FLAi0GcSlvUM3yGTjtus8MNxlQEE ZLjS/ZK9D+kRSjgEvoUjZ95vtzVGKgNIvEesH9faGbnhD++E58lWg7X7BWjCLCQJoBJa VXuq/6dw2+YPz3thxemOm7VmA6tXLdpX7HL3KSxmrqVSjdFe7iq1ahIGbfr9bAhx5ebo EPjw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=YXFqo6VZvGSToN8lCiRCornAXDmfuWZUPGyDM3k2fb0=; b=0d24PKEVJvWtd18HG/bMEtEXKu35Nx8Aespfl9/YKKkbEwTciByGawl567oZNMibx4 PSHvlA++7NoX5TP4cQlNc8RSmv5Yb53fpwl42lvCdEiHDRnm15evcaahLTsLs30mOZyx RVPo5dU6voljtgheUsOYJOgatwmbY6A8HrtYGvrNXM6+tgyAFeXXEbOTn8fDbYV0xCtd MJ/k7B3G9ILxn7G0iDoyvSIT12TlvrebDP5RkoTsqzjWPHHjRXgwOs+glSzWMvEKBgps +X0rdiM1YjmNT648Ey0Pq85qKbEELgTXMetdeijdjSG9epkH+uN8HSGkpwIBTgoQ1vh7 d7Rg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id hk1si2818394ejb.497.2020.06.30.19.39.14; Tue, 30 Jun 2020 19:39:37 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726756AbgGACic (ORCPT + 99 others); Tue, 30 Jun 2020 22:38:32 -0400 Received: from foss.arm.com ([217.140.110.172]:41908 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725988AbgGACic (ORCPT ); Tue, 30 Jun 2020 22:38:32 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id EEDA731B; Tue, 30 Jun 2020 19:38:31 -0700 (PDT) Received: from entos-d05.shanghai.arm.com (entos-d05.shanghai.arm.com [10.169.40.35]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id D4E723F73C; Tue, 30 Jun 2020 19:38:28 -0700 (PDT) From: Jianyong Wu To: ericvh@gmail.com, lucho@ionkov.net, asmadeus@codewreck.org, v9fs-developer@lists.sourceforge.net Cc: linux-kernel@vger.kernel.org, Steve.Capper@arm.com, Kaly.Xin@arm.com, justin.he@arm.com, jianyong.wu@arm.com, wei.chen@arm.com Subject: [PATCH v2] 9p: retrieve fid from file when file instance exist. Date: Wed, 1 Jul 2020 10:38:21 +0800 Message-Id: <20200701023821.5387-1-jianyong.wu@arm.com> X-Mailer: git-send-email 2.17.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In the current setattr implementation in 9p, fid is always retrieved from dentry no matter file instance exists or not. There may be some info related to opened file instance dropped. so it's better to retrieve fid from file instance if file instance is passed to setattr. for example: fd=open("tmp", O_RDWR); ftruncate(fd, 10); The file context related with fd will be lost as fid is always retrieved from dentry, then the backend can't get the info of file context. It is against the original intention of user and may lead to bug. Signed-off-by: Jianyong Wu --- fs/9p/vfs_inode.c | 6 +++++- fs/9p/vfs_inode_dotl.c | 6 +++++- 2 files changed, 10 insertions(+), 2 deletions(-) diff --git a/fs/9p/vfs_inode.c b/fs/9p/vfs_inode.c index c9255d399917..b33574d347fa 100644 --- a/fs/9p/vfs_inode.c +++ b/fs/9p/vfs_inode.c @@ -1100,7 +1100,11 @@ static int v9fs_vfs_setattr(struct dentry *dentry, struct iattr *iattr) retval = -EPERM; v9ses = v9fs_dentry2v9ses(dentry); - fid = v9fs_fid_lookup(dentry); + if (iattr->ia_valid & ATTR_FILE) { + fid = iattr->ia_file->private_data; + WARN_ON(!fid); + } else + fid = v9fs_fid_lookup(dentry); if(IS_ERR(fid)) return PTR_ERR(fid); diff --git a/fs/9p/vfs_inode_dotl.c b/fs/9p/vfs_inode_dotl.c index 60328b21c5fb..ae714f1a630f 100644 --- a/fs/9p/vfs_inode_dotl.c +++ b/fs/9p/vfs_inode_dotl.c @@ -560,7 +560,11 @@ int v9fs_vfs_setattr_dotl(struct dentry *dentry, struct iattr *iattr) p9attr.mtime_sec = iattr->ia_mtime.tv_sec; p9attr.mtime_nsec = iattr->ia_mtime.tv_nsec; - fid = v9fs_fid_lookup(dentry); + if (iattr->ia_valid & ATTR_FILE) { + fid = iattr->ia_file->private_data; + WARN_ON(!fid); + } else + fid = v9fs_fid_lookup(dentry); if (IS_ERR(fid)) return PTR_ERR(fid); -- 2.17.1