Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S966881AbdIZAX1 (ORCPT ); Mon, 25 Sep 2017 20:23:27 -0400 Received: from ipmail01.adl2.internode.on.net ([150.101.137.133]:10968 "EHLO ipmail01.adl2.internode.on.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S936605AbdIZAXU (ORCPT ); Mon, 25 Sep 2017 20:23:20 -0400 X-IronPort-Anti-Spam-Filtered: true X-IronPort-Anti-Spam-Result: =?us-ascii?q?A2C1BACVnMlZ//yBpztbhVyDUotfpyiCE?= =?us-ascii?q?oU/BAIChHcXAwEBAQEBAQFrKIUZAQU6HCMQCAMYCSUPBSUDIROKMqpSi1Mhgwq?= =?us-ascii?q?IYop2BYoLB4kRjXyUT5MTln8hATWBDjIhCB0Vh3guiw4BAQE?= Date: Tue, 26 Sep 2017 09:38:12 +1000 From: Dave Chinner To: Ross Zwisler Cc: Andrew Morton , linux-kernel@vger.kernel.org, "Darrick J. Wong" , "J. Bruce Fields" , Christoph Hellwig , Dan Williams , Jan Kara , Jeff Layton , linux-fsdevel@vger.kernel.org, linux-mm@kvack.org, linux-nvdimm@lists.01.org, linux-xfs@vger.kernel.org Subject: Re: [PATCH 1/7] xfs: always use DAX if mount option is used Message-ID: <20170925233812.GM10955@dastard> References: <20170925231404.32723-1-ross.zwisler@linux.intel.com> <20170925231404.32723-2-ross.zwisler@linux.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20170925231404.32723-2-ross.zwisler@linux.intel.com> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1588 Lines: 43 On Mon, Sep 25, 2017 at 05:13:58PM -0600, Ross Zwisler wrote: > Before support for the per-inode DAX flag was disabled the XFS the code had > an issue where the user couldn't reliably tell whether or not DAX was being > used to service page faults and I/O when the DAX mount option was used. In > this case each inode within the mounted filesystem started with S_DAX set > due to the mount option, but it could be cleared if someone touched the > individual inode flag. > > For example (v4.13 and before): > > # mount | grep dax > /dev/pmem0 on /mnt type xfs > (rw,relatime,seclabel,attr2,dax,inode64,sunit=4096,swidth=4096,noquota) > > # touch /mnt/a /mnt/b # both files currently use DAX > > # xfs_io -c "lsattr" /mnt/* # neither has the DAX inode option set > ----------e----- /mnt/a > ----------e----- /mnt/b > > # xfs_io -c "chattr -x" /mnt/a # this clears S_DAX for /mnt/a > > # xfs_io -c "lsattr" /mnt/* > ----------e----- /mnt/a > ----------e----- /mnt/b That's really a bug in the lsattr code, yes? If we've cleared the S_DAX flag for the inode, then why is it being reported in lsattr? Or if we failed to clear the S_DAX flag in the 'chattr -x' call, then isn't that the bug that needs fixing? Remember, the whole point of the dax inode flag was to be able to override the mount option setting so that admins could turn off/on dax for the things that didn't/did work with DAX correctly so they didn't need multiple filesystems on pmem to segregate the apps that did/didn't work with DAX... Cheers, Dave. -- Dave Chinner david@fromorbit.com