Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp2029739ybv; Sat, 8 Feb 2020 11:35:43 -0800 (PST) X-Google-Smtp-Source: APXvYqzSKZusikFXLkbn8VwCnylXQdS2CSUYng4uaqGFrnhWhp1rtNnthY3n+MSF1JL06qMaQ6XJ X-Received: by 2002:a05:6830:2110:: with SMTP id i16mr4261610otc.337.1581190543570; Sat, 08 Feb 2020 11:35:43 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581190543; cv=none; d=google.com; s=arc-20160816; b=HjcOJ6NHjk8BpKTPpRWv3s24J8dknENCfCi8fO/wl2jffwcx7l/qNzNrWMrNmbxD9h a2vEG5mnKgBccBpGghwgIttV7PdGd8w3/jogKhMSEyjUWD6b6HIxjeh4lxWjR+gfuPV0 wAzEm+WEEEGO9MNCb/4afEnd50TuMFfWGsf3bjd+FNqu+ZB3/OUhQ9NihTb+JCH7S21o 8ZrsPMZ7g7TOhCRT8nENp6I32Epw9JvmeQdCyk6POtVGq3/aOL2OrFzhDlmsILdTWg5S XzcqD0dh7dtP6TKIx7jgLTxMmNWmLw9MtUi/povYO+vaEqeNJr4c5dqnk1wm7c1FhOrA +8TQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=R6rMsb2t/LZfNAzU7+ILNgi812kGayxzwa/Ol/koQXA=; b=yQ9tGhcMGK6xmpBunWgE6e/frp1jTGBHi6W5Fegdaaa4TyflhVgknJLoFlU18fj5fL eb3gjzevOe1TKI/NiEh0m7JTY8ZylVM9Cszwj2Jg06vkt1RkHCvSQ1Mv9HgSc3jyilpL 3VLN3KqZR1n32hceyM53FqVx2ek3hW+r1VMxYklFkeKFEmMxldz1t96NRKdIN7d9L/wQ 0owYEHUuhkIOXv64iDRo0SdqqrovFGkgP3ght2xKofpVGGf7+yL5OLBlFHjqctQwlu2/ 2i8fC1rKzEpZGlwCzE33WQ26FIBAPT5gljTYUN9e4AyCdOdKvfF/hEAM8qOZYhuVScDa C9dA== 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=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f23si2097218oti.283.2020.02.08.11.35.32; Sat, 08 Feb 2020 11:35:43 -0800 (PST) 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=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727605AbgBHTex (ORCPT + 99 others); Sat, 8 Feb 2020 14:34:53 -0500 Received: from mga05.intel.com ([192.55.52.43]:32901 "EHLO mga05.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727563AbgBHTeu (ORCPT ); Sat, 8 Feb 2020 14:34:50 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga007.fm.intel.com ([10.253.24.52]) by fmsmga105.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 08 Feb 2020 11:34:50 -0800 X-IronPort-AV: E=Sophos;i="5.70,418,1574150400"; d="scan'208";a="225859201" Received: from iweiny-desk2.sc.intel.com (HELO localhost) ([10.3.52.157]) by fmsmga007-auth.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 08 Feb 2020 11:34:50 -0800 From: ira.weiny@intel.com To: linux-kernel@vger.kernel.org Cc: Ira Weiny , Alexander Viro , "Darrick J. Wong" , Dan Williams , Dave Chinner , Christoph Hellwig , "Theodore Y. Ts'o" , Jan Kara , linux-ext4@vger.kernel.org, linux-xfs@vger.kernel.org, linux-fsdevel@vger.kernel.org Subject: [PATCH v3 04/12] fs/xfs: Clean up DAX support check Date: Sat, 8 Feb 2020 11:34:37 -0800 Message-Id: <20200208193445.27421-5-ira.weiny@intel.com> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20200208193445.27421-1-ira.weiny@intel.com> References: <20200208193445.27421-1-ira.weiny@intel.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Ira Weiny Rather than open coding xfs_inode_supports_dax() in xfs_ioctl_setattr_dax_invalidate() export xfs_inode_supports_dax() and call it in preparation for swapping dax flags. This also means updating xfs_inode_supports_dax() to return true for a directory. Signed-off-by: Ira Weiny --- fs/xfs/xfs_ioctl.c | 16 +++------------- fs/xfs/xfs_iops.c | 8 ++++++-- fs/xfs/xfs_iops.h | 2 ++ 3 files changed, 11 insertions(+), 15 deletions(-) diff --git a/fs/xfs/xfs_ioctl.c b/fs/xfs/xfs_ioctl.c index 1a57be696810..da1eb2bdb386 100644 --- a/fs/xfs/xfs_ioctl.c +++ b/fs/xfs/xfs_ioctl.c @@ -1190,23 +1190,13 @@ xfs_ioctl_setattr_dax_invalidate( int *join_flags) { struct inode *inode = VFS_I(ip); - struct super_block *sb = inode->i_sb; int error; *join_flags = 0; - /* - * It is only valid to set the DAX flag on regular files and - * directories on filesystems where the block size is equal to the page - * size. On directories it serves as an inherited hint so we don't - * have to check the device for dax support or flush pagecache. - */ - if (fa->fsx_xflags & FS_XFLAG_DAX) { - struct xfs_buftarg *target = xfs_inode_buftarg(ip); - - if (!bdev_dax_supported(target->bt_bdev, sb->s_blocksize)) - return -EINVAL; - } + if ((fa->fsx_xflags & FS_XFLAG_DAX) == FS_XFLAG_DAX && + !xfs_inode_supports_dax(ip)) + return -EINVAL; /* If the DAX state is not changing, we have nothing to do here. */ if ((fa->fsx_xflags & FS_XFLAG_DAX) && diff --git a/fs/xfs/xfs_iops.c b/fs/xfs/xfs_iops.c index a7db50d923d4..eebec159d873 100644 --- a/fs/xfs/xfs_iops.c +++ b/fs/xfs/xfs_iops.c @@ -1246,14 +1246,18 @@ xfs_inode_mount_is_dax( } /* Figure out if this file actually supports DAX. */ -static bool +bool xfs_inode_supports_dax( struct xfs_inode *ip) { struct xfs_mount *mp = ip->i_mount; /* Only supported on non-reflinked files. */ - if (!S_ISREG(VFS_I(ip)->i_mode) || xfs_is_reflink_inode(ip)) + if (xfs_is_reflink_inode(ip)) + return false; + + /* Only supported on regular files and directories. */ + if (!(S_ISREG(VFS_I(ip)->i_mode) || S_ISDIR(VFS_I(ip)->i_mode))) return false; /* Block size must match page size */ diff --git a/fs/xfs/xfs_iops.h b/fs/xfs/xfs_iops.h index 4d24ff309f59..f24fec8de1d6 100644 --- a/fs/xfs/xfs_iops.h +++ b/fs/xfs/xfs_iops.h @@ -24,4 +24,6 @@ extern int xfs_setattr_nonsize(struct xfs_inode *ip, struct iattr *vap, extern int xfs_vn_setattr_nonsize(struct dentry *dentry, struct iattr *vap); extern int xfs_vn_setattr_size(struct dentry *dentry, struct iattr *vap); +extern bool xfs_inode_supports_dax(struct xfs_inode *ip); + #endif /* __XFS_IOPS_H__ */ -- 2.21.0