Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp4179986pxk; Tue, 8 Sep 2020 12:46:32 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx7iQPA7bx3G873+fiRo7xOaGWgdiTR2ibM/yh8PTvE4ifcYaNxUJy5ZtMm3d0vpeVgzC/B X-Received: by 2002:a50:8523:: with SMTP id 32mr693734edr.282.1599594392425; Tue, 08 Sep 2020 12:46:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1599594392; cv=none; d=google.com; s=arc-20160816; b=TFPgmaw98mnEyDKI4dk1x9o4daK/5M9gRmEd73bczdWxgF6M2pc7d9Hj1UAchTf8mv Yg/0/Jgo1KsBYQVOs6s7ntDxLVgu68ebbIq7p/1CYgYEOh0JP+XlRLNtn+UPgaxwUb4l TARMS4fVj8newYZYcgxQ3eASbb4YkQv2H21sV0u/P5K33GnPI6kel3wC3kBwmDFEZ9kl YhsD9DrJr5rAD/LYvz8DpafzxY3w3qjSTEOc3MAPb2FjbckTbujR4s9fTyy1mnjkW5f6 MGjqa+A7eLVntiPs15cIyASRAFFtDnExwbfEcxlebogESyzQzVobLVtAMjp8F5kV5XnP tJoQ== 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 :user-agent:references:in-reply-to:date:cc:to:from:subject :message-id:dkim-signature; bh=akefHF7zGfuMYRKFkMWwuRLHSRmgEPC6X78t4uHgYhs=; b=LoNkjJb3MayFQBOcE2KaN6IJRzCyKetCW0sGkvf5PSqoLeoEHlzAdzxruKBjdBvC2o 0RFxhO5ZZJL5frsoZOIlGaEehxF8+d90os/bWLpeOFBFJIdf4ExyWsKYHeOrXTSjIgLh ZvvU+SXcvubE+BU7mLIk8Dut0XIcV/DaO46xIFP1bKufU8awZo6hjS+cRdXjPTSM0Sfc CkwoMhMbIp+pgHyNBcEpqtOQZ1yXwKi6oFih5WbH0FXkAflqNh6uyrrMNWJStlHR2kQR 3TpKhkiFcN2gDfqbnYYDE6xurnjkDE+KRcC/QSaFzS29dd+oRVkrgPoHfUorMZ847GMo 9kZQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=CvcYBcII; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id pj10si16969ejb.398.2020.09.08.12.46.09; Tue, 08 Sep 2020 12:46:32 -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; dkim=pass header.i=@kernel.org header.s=default header.b=CvcYBcII; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731305AbgIHToo (ORCPT + 99 others); Tue, 8 Sep 2020 15:44:44 -0400 Received: from mail.kernel.org ([198.145.29.99]:45600 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731791AbgIHTof (ORCPT ); Tue, 8 Sep 2020 15:44:35 -0400 Received: from tleilax.poochiereds.net (68-20-15-154.lightspeed.rlghnc.sbcglobal.net [68.20.15.154]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 5D1E720578; Tue, 8 Sep 2020 19:44:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1599594273; bh=TwSgaQVWEpyncboF4JaD9IhTXHoxnoQIBmEUk68HUJI=; h=Subject:From:To:Cc:Date:In-Reply-To:References:From; b=CvcYBcII98mNXdOt3ahcND/odmUUtF1qJ7jdSiGu5rWQigwBgkEIGnxpVHeYd2rj2 BSuXy9Eu/sB6mfBPSMnCgiune1xkJVc0Frzvajn6liJxdAa5Xy6U2YFaQd5sWObBlO ey0gPuJXFnLabJ79cydkxypftdh00fQbSdgW+K9o= Message-ID: Subject: Re: [PATCH] fsync.2: ERRORS: add EIO and ENOSPC From: Jeff Layton To: Jan Kara , "Michael Kerrisk (man-pages)" Cc: milan.opensource@gmail.com, lkml , Andrew Morton , "linux-fsdevel@vger.kernel.org" Date: Tue, 08 Sep 2020 15:44:32 -0400 In-Reply-To: <20200908112742.GA2956@quack2.suse.cz> References: <1598685186-27499-1-git-send-email-milan.opensource@gmail.com> <20200908112742.GA2956@quack2.suse.cz> Content-Type: text/plain; charset="UTF-8" User-Agent: Evolution 3.36.5 (3.36.5-1.fc32) MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 2020-09-08 at 13:27 +0200, Jan Kara wrote: > Added Jeff to CC since he has written the code... > > On Mon 07-09-20 09:11:06, Michael Kerrisk (man-pages) wrote: > > [Widening the CC to include Andrew and linux-fsdevel@] > > [Milan: thanks for the patch, but it's unclear to me from your commit > > message how/if you verified the details.] > > > > Andrew, maybe you (or someone else) can comment, since long ago your > > > > commit f79e2abb9bd452d97295f34376dedbec9686b986 > > Author: Andrew Morton > > Date: Fri Mar 31 02:30:42 2006 -0800 > > > > included a comment that is referred to in stackoverflow discussion > > about this topic (that SO discussion is in turn referred to by > > https://bugzilla.kernel.org/show_bug.cgi?id=194757). > > > > The essence as I understand it, is this: > > (1) fsync() (and similar) may fail EIO or ENOSPC, at which point data > > has not been synced. > > (2) In this case, the EIO/ENOSPC setting is cleared so that... > > (3) A subsequent fsync() might return success, but... > > (4) That doesn't mean that the data in (1) landed on the disk. > > Correct. > > > The proposed manual page patch below wants to document this, but I'd > > be happy to have an FS-knowledgeable person comment before I apply. > > Just a small comment below: > > > On Sat, 29 Aug 2020 at 09:13, wrote: > > > From: Milan Shah > > > > > > This Fix addresses Bug 194757. > > > Ref: https://bugzilla.kernel.org/show_bug.cgi?id=194757 > > > --- > > > man2/fsync.2 | 13 +++++++++++++ > > > 1 file changed, 13 insertions(+) > > > > > > diff --git a/man2/fsync.2 b/man2/fsync.2 > > > index 96401cd..f38b3e4 100644 > > > --- a/man2/fsync.2 > > > +++ b/man2/fsync.2 > > > @@ -186,6 +186,19 @@ In these cases disk caches need to be disabled using > > > or > > > .BR sdparm (8) > > > to guarantee safe operation. > > > + > > > +When > > > +.BR fsync () > > > +or > > > +.BR fdatasync () > > > +returns > > > +.B EIO > > > +or > > > +.B ENOSPC > > > +any error flags on pages in the file mapping are cleared, so subsequent synchronisation attempts > > > +will return without error. It is > > > +.I not > > > +safe to retry synchronisation and assume that a non-error return means prior writes are now on disk. > > > .SH SEE ALSO > > > .BR sync (1), > > > .BR bdflush (2), > > So the error state isn't really stored "on pages in the file mapping". > Current implementation (since 4.14) is that error state is stored in struct > file (I think this tends to be called "file description" in manpages) and > so EIO / ENOSPC is reported once for each file description of the file that > was open before the error happened. Not sure if we want to be so precise in > the manpages or if it just confuses people. Anyway your takeway that no > error on subsequent fsync() does not mean data was written is correct. > > Thinking about it more, I think we ought to spell this out explicitly as we can in the manpage. This is a point of confusion for a lot of people and not understanding this can lead to data integrity bugs. Maybe something like this in the NOTES section? ''' When fsync returns an error, the file is considered to be "clean". A subsequent call to fsync will not result in a reattempt to write out the data, unless that data has been rewritten. Applications that want to reattempt writing to the file after a transient error must re-write their data. ''' To be clear: In practice, you'd only have to write enough to redirty each page in most cases. Also, it is hard to claim that the above behavior is universally true. A filesystem could opt to keep the pages dirty for some errors, but the vast majority just toss out the data whenever there is a writeback problem. -- Jeff Layton