From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id 043FEC3271E for ; Mon, 8 Jul 2024 18:47:48 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 688A16B0095; Mon, 8 Jul 2024 14:47:48 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 642E76B0096; Mon, 8 Jul 2024 14:47:48 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 4FFCF6B0098; Mon, 8 Jul 2024 14:47:48 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0015.hostedemail.com [216.40.44.15]) by kanga.kvack.org (Postfix) with ESMTP id 2AC956B0095 for ; Mon, 8 Jul 2024 14:47:48 -0400 (EDT) Received: from smtpin05.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay06.hostedemail.com (Postfix) with ESMTP id CA1FAA4966 for ; Mon, 8 Jul 2024 18:47:47 +0000 (UTC) X-FDA: 82317469374.05.FA97E10 Received: from sin.source.kernel.org (sin.source.kernel.org [145.40.73.55]) by imf25.hostedemail.com (Postfix) with ESMTP id 707CAA0020 for ; Mon, 8 Jul 2024 18:47:45 +0000 (UTC) Authentication-Results: imf25.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=JVrSYqr+; spf=pass (imf25.hostedemail.com: domain of djwong@kernel.org designates 145.40.73.55 as permitted sender) smtp.mailfrom=djwong@kernel.org; dmarc=pass (policy=none) header.from=kernel.org ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1720464426; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=DYPjLMgG+zKP2YfuxDqaA6mXNvf1sWEIq+q6iv4Uk+w=; b=W5metakHdUbN4BCSlsaGMrVqLkFOAxTixQaiC16EXqEm/NB6CYSF2Gh9Q+SKE5CBTU2ARA wg237kcy9Mvdw/I4Jppzjy0peHZPWWhOo310ZiawVkzZ4Ynwslmn8dS/eJrQ/wkWKwNSAp ozhdbDLVFLeHHHr01+ggatz4FlIkyb4= ARC-Authentication-Results: i=1; imf25.hostedemail.com; dkim=pass header.d=kernel.org header.s=k20201202 header.b=JVrSYqr+; spf=pass (imf25.hostedemail.com: domain of djwong@kernel.org designates 145.40.73.55 as permitted sender) smtp.mailfrom=djwong@kernel.org; dmarc=pass (policy=none) header.from=kernel.org ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1720464426; a=rsa-sha256; cv=none; b=Y7iFogNBUH4T4knL6Ykjb2sngCSHKn0adOH9Ihq8VOH6nxR2ntS6M6L0p88q7pXMwCyWZ+ YizCKjG2z4ZZ4rozkZAfoYodi2warX8VSU8Szq/GoMG7+8vXzKfsCFtFDi/pg/bN65xZsF G8gPvHUZWZyKcAZuKM6N8AvN9UUtT4A= Received: from smtp.kernel.org (transwarp.subspace.kernel.org [100.75.92.58]) by sin.source.kernel.org (Postfix) with ESMTP id C1B89CE0ED4; Mon, 8 Jul 2024 18:47:40 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 19259C116B1; Mon, 8 Jul 2024 18:47:40 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1720464460; bh=v31gl1I9OIcRmv77OmqWlCzEeZq6WOtR9ckY+p4HFoM=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=JVrSYqr+1qSVnArfid1TPu00dGCFcKaSnisHbXvjsY9S6ELI7mwnhSKVTbSd2oQpI mRMITfr0ATkLE8+3WFFLhRaOsjMh2U3HT1wc7kdVE5G+1r9YXbqUCkzoTGU6vdco14 m9iGJSXziOeQ8FbKTrhds3sZ9Kbgjd8zwExhR8BIwDJGbCvtcamUor/gq5w0cTu2nc 6Vjkj4JpcUvaYO/BLLD/MwxH+tESDtfmSUkViWJASao1Z9NnIijNm0UwV12PCDc3jx CT/vD0y+ltf0G366leHHF0oi9NKV3tK9D3C3B1DMzxoyd8gFJuKjgOn7HIyM6ymeoi ebz1/5YzFOetA== Date: Mon, 8 Jul 2024 11:47:39 -0700 From: "Darrick J. Wong" To: Jeff Layton Cc: Alexander Viro , Christian Brauner , Jan Kara , Steven Rostedt , Masami Hiramatsu , Mathieu Desnoyers , Chandan Babu R , Theodore Ts'o , Andreas Dilger , Chris Mason , Josef Bacik , David Sterba , Hugh Dickins , Andrew Morton , Jonathan Corbet , Dave Chinner , Andi Kleen , Christoph Hellwig , Uros Bizjak , Kent Overstreet , kernel-team@fb.com, linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org, linux-trace-kernel@vger.kernel.org, linux-xfs@vger.kernel.org, linux-ext4@vger.kernel.org, linux-btrfs@vger.kernel.org, linux-mm@kvack.org, linux-nfs@vger.kernel.org, linux-doc@vger.kernel.org Subject: Re: [PATCH v4 6/9] xfs: switch to multigrain timestamps Message-ID: <20240708184739.GP612460@frogsfrogsfrogs> References: <20240708-mgtime-v4-0-a0f3c6fb57f3@kernel.org> <20240708-mgtime-v4-6-a0f3c6fb57f3@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20240708-mgtime-v4-6-a0f3c6fb57f3@kernel.org> X-Rspamd-Server: rspam06 X-Rspamd-Queue-Id: 707CAA0020 X-Stat-Signature: smjm3tms33krsk8bcrrs7gjhg9y9p7j6 X-Rspam-User: X-HE-Tag: 1720464465-563333 X-HE-Meta: U2FsdGVkX1+IxScH5Yp7CHBapbD7PVoqqQVHIjPkn+h0TNOW41bTSRCHEMuZ7SSgw1LmmdaOFz8b+MxM9abfGD/s0vPssIjaEZyi4ClN/79CxQXMWu0+1NTO7TCy/XUvA5B31LVQlxO/ZSS+PdkHot1JiRzkb+U59zpDWpcNra0pFLn543ACAXKTHEtN1zb+YZVlbEUDhd+utlos7KCln2FcqPiGFaJ5wiHyhWn/aqreBCJ/LMxy7IGuPxTKXNlpAEfya9wJRdxyzL1HUzARWVI2kevxUFUoi9J46PsTGrKzwkTdhlVI8tiXBW+ymoLpWd6czI/tsjD1Xc3TGKZS6jGyzORKjlqT5XG0+z1NzRG/u75S5F/++FY36tBotqd27gVBvwicIXD7mh5sxl2sSxduMk4SYkba/Y2YobPDCHjoY20Sehq4C+Qf8jPCxag+aELTQue+MtE0IICHoLz0ELhVUtE7TeNIAC92vweIEu1AbiA0BYxHk4fXY4QRTdIDzwwn47sBkJWVy4Wn3Q1Nqw0avV6ronLYqcs13KszLSkwSvWikT4wEysloRy/MpuRNUUtzVWIsmEnANIU81fn/X0eDtdcVsYi+A4LUzGvheoYj1YLDRgg+ccNvnoRNwXj5qaumejj5Ypt7s3Sx8CPyKajQIzCDXuYS9g4igD2/ZzJyt5Am9lGhICyKRjyXbNlOl17SKUUmTHC1HqW0NyVp47sjiDDiQRKkOif37qdPMaSS5F7zEBsKTShvd6ia2yitp4cQ9sqShlO4O90omZznKgekvGD+VwdrRdHimvq0DYtklFWhr1443CzmFmywgXGc2l+vl2L+Pi6+O6FNAtHBlNXSuZoNkjF05ixtE8kqRNZSSmc9CtQ5EfwEFJ7QTmr5Ym+i7atgemKJCPL3r4N8ehiGzUJLnAAzxPAUjHh1xC9b6byfaaRDzirHnXKZJtG1E8QVGkeoXf7w6hsU4m wzrR/kbz XVuThZGmAHRkbgTJF5SmYn6V2f9M35znWhy7onUUt7noLi138DNFUP4pNb9rjjFAy1vN7KRxS+3NEXyI1HwFoRh7L5BCtam68QPd8d4eM6sFOQE8ZbREwKfbjuGesNCveU2NQ+/6JciOQt1x4G9Z0AJZGZlSPQsV5m/AKHfTEW1HD4rVtDkR40N8x90LfSIlXtxRW2RlBddaC8HO365NA3PxWiEKtdhCZYT0JGr5E9gvGAQebH79qwjQKmOELZ4pbRezFgPfmS1mFZKLwoccJMOydQw== X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: List-Subscribe: List-Unsubscribe: On Mon, Jul 08, 2024 at 11:53:39AM -0400, Jeff Layton wrote: > Enable multigrain timestamps, which should ensure that there is an > apparent change to the timestamp whenever it has been written after > being actively observed via getattr. > > Also, anytime the mtime changes, the ctime must also change, and those > are now the only two options for xfs_trans_ichgtime. Have that function > unconditionally bump the ctime, and ASSERT that XFS_ICHGTIME_CHG is > always set. > > Finally, stop setting STATX_CHANGE_COOKIE in getattr, since the ctime > should give us better semantics now. > > Signed-off-by: Jeff Layton > --- > fs/xfs/libxfs/xfs_trans_inode.c | 6 +++--- > fs/xfs/xfs_iops.c | 10 +++------- > fs/xfs/xfs_super.c | 2 +- > 3 files changed, 7 insertions(+), 11 deletions(-) > > diff --git a/fs/xfs/libxfs/xfs_trans_inode.c b/fs/xfs/libxfs/xfs_trans_inode.c > index 69fc5b981352..1f3639bbf5f0 100644 > --- a/fs/xfs/libxfs/xfs_trans_inode.c > +++ b/fs/xfs/libxfs/xfs_trans_inode.c > @@ -62,12 +62,12 @@ xfs_trans_ichgtime( > ASSERT(tp); > xfs_assert_ilocked(ip, XFS_ILOCK_EXCL); > > - tv = current_time(inode); > + /* If the mtime changes, then ctime must also change */ > + ASSERT(flags & XFS_ICHGTIME_CHG); > > + tv = inode_set_ctime_current(inode); > if (flags & XFS_ICHGTIME_MOD) > inode_set_mtime_to_ts(inode, tv); > - if (flags & XFS_ICHGTIME_CHG) > - inode_set_ctime_to_ts(inode, tv); > if (flags & XFS_ICHGTIME_CREATE) > ip->i_crtime = tv; > } > diff --git a/fs/xfs/xfs_iops.c b/fs/xfs/xfs_iops.c > index a00dcbc77e12..d25872f818fa 100644 > --- a/fs/xfs/xfs_iops.c > +++ b/fs/xfs/xfs_iops.c > @@ -592,8 +592,9 @@ xfs_vn_getattr( > stat->gid = vfsgid_into_kgid(vfsgid); > stat->ino = ip->i_ino; > stat->atime = inode_get_atime(inode); > - stat->mtime = inode_get_mtime(inode); > - stat->ctime = inode_get_ctime(inode); > + > + fill_mg_cmtime(stat, request_mask, inode); Sooo... for setting up a commit-range operation[1], XFS_IOC_START_COMMIT could populate its freshness data by calling: struct kstat dummy; fill_mg_ctime(&dummy, STATX_CTIME | STATX_MTIME, inode); and then using dummy.[cm]time to populate the freshness data that it gives to userspace, right? Having set QUERIED, a write to the file immediately afterwards will cause a (tiny) increase in ctime_nsec which will cause the XFS_IOC_COMMIT_RANGE to reject the commit[2]. Right? --D [1] https://lore.kernel.org/linux-xfs/20240227174649.GL6184@frogsfrogsfrogs/ [2] https://git.kernel.org/pub/scm/linux/kernel/git/djwong/xfs-linux.git/commit/?h=atomic-file-commits&id=0520d89c2698874c1f56ddf52ec4b8a3595baa14 > + > stat->blocks = XFS_FSB_TO_BB(mp, ip->i_nblocks + ip->i_delayed_blks); > > if (xfs_has_v3inodes(mp)) { > @@ -603,11 +604,6 @@ xfs_vn_getattr( > } > } > > - if ((request_mask & STATX_CHANGE_COOKIE) && IS_I_VERSION(inode)) { > - stat->change_cookie = inode_query_iversion(inode); > - stat->result_mask |= STATX_CHANGE_COOKIE; > - } > - > /* > * Note: If you add another clause to set an attribute flag, please > * update attributes_mask below. > diff --git a/fs/xfs/xfs_super.c b/fs/xfs/xfs_super.c > index 27e9f749c4c7..210481b03fdb 100644 > --- a/fs/xfs/xfs_super.c > +++ b/fs/xfs/xfs_super.c > @@ -2052,7 +2052,7 @@ static struct file_system_type xfs_fs_type = { > .init_fs_context = xfs_init_fs_context, > .parameters = xfs_fs_parameters, > .kill_sb = xfs_kill_sb, > - .fs_flags = FS_REQUIRES_DEV | FS_ALLOW_IDMAP, > + .fs_flags = FS_REQUIRES_DEV | FS_ALLOW_IDMAP | FS_MGTIME, > }; > MODULE_ALIAS_FS("xfs"); > > > -- > 2.45.2 > >