Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp5754705pxu; Wed, 23 Dec 2020 04:50:15 -0800 (PST) X-Google-Smtp-Source: ABdhPJzLfDxm5NxAnnP3Ri5D55VH0LPNR4Zo99+Pd4IfL1jarHiIbFoVcJiZaDuwHEINu3FMex3S X-Received: by 2002:a50:fe0e:: with SMTP id f14mr24910621edt.159.1608727815005; Wed, 23 Dec 2020 04:50:15 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1608727814; cv=none; d=google.com; s=arc-20160816; b=Zi13LNZhMlI7YpCxIvtjUDK0JTeWZAmUGU/u9WzCi7QbNzotZk9dOy7uce2OuBnTO5 VW16O6yPfTZatF1kluFS1BrE2qsM73OCSJ3s9TQdRI3pSzItnuAI6X4D0N54DBY8HacE hn4NkRLSbm0kGzy1DQrzoWS8jopfhRzkw4e7BrLL2utDVGTEU2gW/nbHVFW1M12vTyhQ Ce3D/y75qo2xc3DV++GkVJ8p88fVwt20zpqe+Sc0XFt5Ct4QhZHjWOJhXqks2gZT/X+i v+h5AwezZ9y9MUsgTxDH7ARfA9wFKcT0eKhNVz9oZixZjlaRq9AVSX89h4abUskF4IWu 5MlA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:date:cc:to:from:subject :message-id:dkim-signature; bh=DWXYj2rMb8kYtOYk1cmtH8wEBjDZE/DAn1icNKesEKg=; b=YlbtrBVXmmVO/aOs1kx/pc9zilCtqKqeXxHGbvOfhPpjp0PkiMkfBcusCcUl8kiNT+ iwr2D31bELKC4vwxnqT/Ha7KxGBzy78RKuWRb9LWXhZj4vU0QTjp6xHkRMOgw5FgBxgl AVi3Iv5foM26kv/oCC4jSXLpUex7O6i3WvT9tnPrhE6B4mdzg4QkWmOiQH0MPDx59AxY CWKn/zm86jhRjr8E48wyNRQjuLXPmF9H8SHvJYtT5YbMhdiMMd2w16GD1x1AKHpbkLT+ l9vxIvuue4G3S6Ffk/Nf5DQrZzzD6/TGlm99ZVkUSTUR3VpzVXNFJDgjZFvF8TbjgvgV y5eA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=ZEituENi; 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 g3si11054925ejf.612.2020.12.23.04.49.52; Wed, 23 Dec 2020 04:50:14 -0800 (PST) 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=k20201202 header.b=ZEituENi; 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 S1728478AbgLWMtg (ORCPT + 99 others); Wed, 23 Dec 2020 07:49:36 -0500 Received: from mail.kernel.org ([198.145.29.99]:35880 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728303AbgLWMtf (ORCPT ); Wed, 23 Dec 2020 07:49:35 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id 203132247F; Wed, 23 Dec 2020 12:48:54 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1608727735; bh=qr6Tgo2rI9O+RPG8qqozKbpDM7yOwFSy58jzf8XnPyc=; h=Subject:From:To:Cc:Date:In-Reply-To:References:From; b=ZEituENikvm+USYFuLfWcMA2BglYEBST0cdzY2zp9G93ZdppwMzhcLp2KH8fBN1hi VgtJv+NFAEKNvUDW4dOYl7taNmPOpzg8zHUqWqWuFibs+Bdef+kIfRjIlOCZba3ipq x1tTnt9dsy+282z2hRBhfpT3akT40X/K2Cbd0dYJLxw0Vb1xa2+yXbbWQr4NBW/nqL zZpvNAYZhwkR5Ss99982GUMsLsk9XXbcamD6mqvl83FG4zLxDgdv+N8157/cx0f/uk zPlfpX0xBxyZvp5F7nxTkCQf6euLGJJqZTJzhFf46gNKM6nOFJTaqLmFYA1aWWoPZC RfO9y1svIVRyg== Message-ID: <3b488048b666f22108e7660eb32e10860a75784a.camel@kernel.org> Subject: Re: [PATCH 2/3] vfs: Add a super block operation to check for writeback errors From: Jeff Layton To: Vivek Goyal , linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org, linux-unionfs@vger.kernel.org Cc: amir73il@gmail.com, sargun@sargun.me, miklos@szeredi.hu, willy@infradead.org, jack@suse.cz, neilb@suse.com, viro@zeniv.linux.org.uk, hch@lst.de Date: Wed, 23 Dec 2020 07:48:52 -0500 In-Reply-To: <20201221195055.35295-3-vgoyal@redhat.com> References: <20201221195055.35295-1-vgoyal@redhat.com> <20201221195055.35295-3-vgoyal@redhat.com> Content-Type: text/plain; charset="ISO-8859-15" User-Agent: Evolution 3.38.2 (3.38.2-1.fc33) MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 2020-12-21 at 14:50 -0500, Vivek Goyal wrote: > Right now we check for errors on super block in syncfs(). > > ret2 = errseq_check_and_advance(&sb->s_wb_err, &f.file->f_sb_err); > > overlayfs does not update sb->s_wb_err and it is tracked on upper filesystem. > So provide a superblock operation to check errors so that filesystem > can provide override generic method and provide its own method to > check for writeback errors. > > Signed-off-by: Vivek Goyal > --- > ?fs/sync.c | 5 ++++- > ?include/linux/fs.h | 1 + > ?2 files changed, 5 insertions(+), 1 deletion(-) > > diff --git a/fs/sync.c b/fs/sync.c > index b5fb83a734cd..57e43a16dfca 100644 > --- a/fs/sync.c > +++ b/fs/sync.c > @@ -176,7 +176,10 @@ SYSCALL_DEFINE1(syncfs, int, fd) > ? ret = sync_filesystem(sb); > ? up_read(&sb->s_umount); > ? > > - ret2 = errseq_check_and_advance(&sb->s_wb_err, &f.file->f_sb_err); > + if (sb->s_op->errseq_check_advance) > + ret2 = sb->s_op->errseq_check_advance(sb, f.file); > + else > + ret2 = errseq_check_and_advance(&sb->s_wb_err, &f.file->f_sb_err); > ? > > ? fdput(f); > ? return ret ? ret : ret2; > diff --git a/include/linux/fs.h b/include/linux/fs.h > index 8667d0cdc71e..4297b6127adf 100644 > --- a/include/linux/fs.h > +++ b/include/linux/fs.h > @@ -1965,6 +1965,7 @@ struct super_operations { > ? struct shrink_control *); > ? long (*free_cached_objects)(struct super_block *, > ? struct shrink_control *); > + int (*errseq_check_advance)(struct super_block *, struct file *); > ?}; > ? > > ?/* Also, the other super_operations generally don't take a superblock pointer when you pass in a different fs object pointer. This should probably just take a struct file * and then the operation can chase pointers to the superblock from there. -- Jeff Layton