Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp6912490ybl; Wed, 15 Jan 2020 12:13:42 -0800 (PST) X-Google-Smtp-Source: APXvYqzPRUslZ5iWkXCOdYn2L4/bIlQ+Ef5aQczsDLL1zNc6bhO9MlB36D1eRIMy45JL2JOqbe+E X-Received: by 2002:aca:45c1:: with SMTP id s184mr1346687oia.158.1579119222349; Wed, 15 Jan 2020 12:13:42 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579119222; cv=none; d=google.com; s=arc-20160816; b=BhuOAlqrR18kL/AzxUMUt3xNAETl/FwnzDF3AsMAE5vuCynoME4qNOC6VGVvWcNEdb VAvBadbK7PCbgLF07qUG3mHLeH0KbiMshSrYsLCVaNaZrzNLexpPJZWAmAqsEBOKyvJc rbFkH+JDV6985/bwSM+q2/NdOZvEyf7fP2blMobVfZlg18KFR92CJNBpLMzQKM8HQue8 w60XKUq/BNficV4hEojTJDlgwEvsHSAYTWTkqZuzfQ7cK8ZlmPO41KM36x8NGetzXkr8 +9+FeNVb6RZ7RXrbSsrveLD7+TZkim59s73gciU5f6CKhKAWn19hGlJJB8pbJ/1gHiNG Hw5g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=ZNerA6RTqwQW5nW1+H5K5Uzw8BJvKQMgJNhaZlAlRYY=; b=t04Gh1kl0JUnobdWM2GRZluhd+FFSCI5hXRiRwuDWjLZafj7TXuYrxPRKAhZFhfRIO nwar9hp8sTyAJEJktBngL8AS1WNz3ATwOdHt0TsbGVftRpUt8hwjIRpMt88bF2yZoJfe Ok7hbRp41nfFoqsI3osRE4PNeY/pJghNFI66kcckCKi3gJmNA2Q9lNbgtQCyElwqQeP+ dNd/1J1YVE88HZD3wl3orPqgA591u/xf5bHZpTFwj+yOSU379d1IYc6Wr9GVwN7hJ/Ks 6+rk3OLxjr630QRsJ3rKMpP1WkgubmnnHgVCmAQzy2hNyuy2AAtzk20I70/Qzb6S2XYq 6+dQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel-com.20150623.gappssmtp.com header.s=20150623 header.b=Ft97un5Q; spf=pass (google.com: best guess record for domain of linux-ext4-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-ext4-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 y205si10376161oig.137.2020.01.15.12.13.29; Wed, 15 Jan 2020 12:13:42 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-ext4-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@intel-com.20150623.gappssmtp.com header.s=20150623 header.b=Ft97un5Q; spf=pass (google.com: best guess record for domain of linux-ext4-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-ext4-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 S1729567AbgAOULE (ORCPT + 99 others); Wed, 15 Jan 2020 15:11:04 -0500 Received: from mail-oi1-f194.google.com ([209.85.167.194]:45559 "EHLO mail-oi1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726566AbgAOULC (ORCPT ); Wed, 15 Jan 2020 15:11:02 -0500 Received: by mail-oi1-f194.google.com with SMTP id n16so16659723oie.12 for ; Wed, 15 Jan 2020 12:11:01 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=intel-com.20150623.gappssmtp.com; s=20150623; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=ZNerA6RTqwQW5nW1+H5K5Uzw8BJvKQMgJNhaZlAlRYY=; b=Ft97un5QqUrNcT2a7r5rLK9Bcn1CGDH85x4lJi33iI5GvOUxp6vygNblPKWeya2a6T X0HIFeiVeuqE2D+saniOTNQWGbo8MKlSfUS0UMcJydL2FDE+2jKMsz4cG8rlk4viB2Af XNOMJ7xGAtdXm+eUDptNXQIDCN2NzQECzscSmosJ8UBLtvVbQyDAkNwphXsSrXWo+gHH 0+cAUmAJVgbv/2p186TFDFyE8v6/+vZ52woVxENpm0uiusWM1856TiiKqNg9Y2DT7K4c IpkO011AaT1GzD9R+yLn0F0pLwaUYU35sLW3epoiCfwAhUYYzDgavjcxnV4iB8iiBj9o aAUg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=ZNerA6RTqwQW5nW1+H5K5Uzw8BJvKQMgJNhaZlAlRYY=; b=FjSJZG1Y3y75gfxhbGymN04GcuBLxkPiMhQM/cHRB++0m691mNCNqzkZ3m3IPR2FzV WiRjg7pXLfkt5kH3OC9HRE+1e5k3lqkv5zrDK2qXRtPPlrXdwdrWC65i37InCIyM6SFk mI1lz02Z/lrJcJ4O37xbbQERx1NnzY400BJG3rrnt0k3dzemRj4QKvPMD5iPA+WMVbWQ e+evRCXoRbTokfGpTLg55FcG4MRT5kTTieUPKcEaZ1a28WYIQ8hjI4b2rbo73FxnAQrk 3Z4cE5Ntq0i8i0n6e0H2EOGMLj/tB3gAe28z1L91ZTq9njwHAffx3mNhJjxYUolVVd/o x7YQ== X-Gm-Message-State: APjAAAUD8cvG/RJISX5fRcxe5pii7VBS1uF83o1Tay7xK+9OSUGOEaJw baMWhmGghrIiRJ1e4T/SebfaamLyHkGISgAR0e9tsQ== X-Received: by 2002:aca:3f54:: with SMTP id m81mr1208667oia.73.1579119061327; Wed, 15 Jan 2020 12:11:01 -0800 (PST) MIME-Version: 1.0 References: <20200110192942.25021-1-ira.weiny@intel.com> <20200110192942.25021-2-ira.weiny@intel.com> <20200115113715.GB2595@quack2.suse.cz> <20200115173834.GD8247@magnolia> <20200115194512.GF23311@iweiny-DESK2.sc.intel.com> In-Reply-To: <20200115194512.GF23311@iweiny-DESK2.sc.intel.com> From: Dan Williams Date: Wed, 15 Jan 2020 12:10:50 -0800 Message-ID: Subject: Re: [RFC PATCH V2 01/12] fs/stat: Define DAX statx attribute To: Ira Weiny Cc: "Darrick J. Wong" , Jan Kara , Linux Kernel Mailing List , Alexander Viro , Dave Chinner , Christoph Hellwig , "Theodore Y. Ts'o" , linux-ext4 , linux-xfs , linux-fsdevel Content-Type: text/plain; charset="UTF-8" Sender: linux-ext4-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-ext4@vger.kernel.org On Wed, Jan 15, 2020 at 11:45 AM Ira Weiny wrote: > > On Wed, Jan 15, 2020 at 09:38:34AM -0800, Darrick J. Wong wrote: > > On Wed, Jan 15, 2020 at 12:37:15PM +0100, Jan Kara wrote: > > > On Fri 10-01-20 11:29:31, ira.weiny@intel.com wrote: > > > > From: Ira Weiny > > > > > > > > In order for users to determine if a file is currently operating in DAX > > > > mode (effective DAX). Define a statx attribute value and set that > > > > attribute if the effective DAX flag is set. > > > > > > > > To go along with this we propose the following addition to the statx man > > > > page: > > > > > > > > STATX_ATTR_DAX > > > > > > > > DAX (cpu direct access) is a file mode that attempts to minimize > > > > "..is a file I/O mode"? > > or "... is a file state ..."? > > > > > software cache effects for both I/O and memory mappings of this > > > > file. It requires a capable device, a compatible filesystem > > > > block size, and filesystem opt-in. > > > > "...a capable storage device..." > > Done > > > > > What does "compatible fs block size" mean? How does the user figure out > > if their fs blocksize is compatible? Do we tell users to refer their > > filesystem's documentation here? > > Perhaps it is wrong for this to be in the man page at all? Would it be better > to assume the file system and block device are already configured properly by > the admin? > > For which the blocksize restrictions are already well documented. ie: > > https://www.kernel.org/doc/Documentation/filesystems/dax.txt > > ? > > How about changing the text to: > > It requires a block device and file system which have been configured > to support DAX. > > ? The goal was to document the gauntlet of checks that __generic_fsdax_supported() performs so someone could debug "why am I not able to get dax operation?" > > > > > > > It generally assumes all > > > > accesses are via cpu load / store instructions which can > > > > minimize overhead for small accesses, but adversely affect cpu > > > > utilization for large transfers. > > > > Will this always be true for persistent memory? For direct-mapped pmem there is no opportunity to do dma offload so it will always be true that application dax access consumes cpu to do I/O where something like NVMe does not. There has been unfruitful to date experiments with the driver using an offload engine for kernel internal I/O, but if you're use case is kernel internal I/O bound then you don't need dax. > > I'm not clear. Did you mean; "this" == adverse utilization for large transfers? > > > > > I wasn't even aware that large transfers adversely affected CPU > > utilization. ;) > > Sure vs using a DMA engine for example. Right, this is purely a statement about cpu memcpy vs device-dma. > > > > > > > File I/O is done directly > > > > to/from user-space buffers. While the DAX property tends to > > > > result in data being transferred synchronously it does not give > > > > "...transferred synchronously, it does not..." > > done. > > > > > > > the guarantees of synchronous I/O that data and necessary > > > > "...it does not guarantee that I/O or file metadata have been flushed to > > the storage device." > > The lack of guarantee here is mainly regarding metadata. > > How about: > > While the DAX property tends to result in data being transferred > synchronously, it does not give the same guarantees of > synchronous I/O where data and the necessary metadata are > transferred together. > > > > > > > metadata are transferred. Memory mapped I/O may be performed > > > > with direct mappings that bypass system memory buffering. > > > > "...with direct memory mappings that bypass kernel page cache." > > Done. > > > > > > > Again > > > > while memory-mapped I/O tends to result in data being > > > > I would move the sentence about "Memory mapped I/O..." to directly after > > the sentence about file I/O being done directly to and from userspace so > > that you don't need to repeat this statement. > > Done. > > > > > > > transferred synchronously it does not guarantee synchronous > > > > metadata updates. A dax file may optionally support being mapped > > > > with the MAP_SYNC flag which does allow cpu store operations to > > > > be considered synchronous modulo cpu cache effects. > > > > How does one detect or work around or deal with "cpu cache effects"? I > > assume some sort of CPU cache flush instruction is what is meant here, > > but I think we could mention the basics of what has to be done here: > > > > "A DAX file may support being mapped with the MAP_SYNC flag, which > > enables a program to use CPU cache flush operations to persist CPU store > > operations without an explicit fsync(2). See mmap(2) for more > > information."? > > That sounds better. I like the reference to mmap as well. > > Ok I changed a couple of things as well. How does this sound? > > > STATX_ATTR_DAX > > DAX (cpu direct access) is a file mode that attempts to minimize s/mode/state/? > software cache effects for both I/O and memory mappings of this > file. It requires a block device and file system which have > been configured to support DAX. It may not require a block device in the future. > > DAX generally assumes all accesses are via cpu load / store > instructions which can minimize overhead for small accesses, but > may adversely affect cpu utilization for large transfers. > > File I/O is done directly to/from user-space buffers and memory > mapped I/O may be performed with direct memory mappings that > bypass kernel page cache. > > While the DAX property tends to result in data being transferred > synchronously, it does not give the same guarantees of > synchronous I/O where data and the necessary metadata are Maybe use "O_SYNC I/O" explicitly to further differentiate the 2 meanings of "synchronous" in this sentence? > transferred together. > > A DAX file may support being mapped with the MAP_SYNC flag, > which enables a program to use CPU cache flush operations to s/operations/instructions/ > persist CPU store operations without an explicit fsync(2). See > mmap(2) for more information. I think this also wants a reference to the Linux interpretation of platform "persistence domains" we were discussing that here [1], but maybe it should be part of a "pmem" manpage that can be referenced from this man page. [1]: http://lore.kernel.org/r/20200108064905.170394-1-aneesh.kumar@linux.ibm.com