Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp1731992imm; Tue, 10 Jul 2018 07:03:35 -0700 (PDT) X-Google-Smtp-Source: AAOMgpdenulqcTb87PMyuku6Y/4A/TnHogWVj7tWofTycL+szq1NVBg2j8ngSXKILs5K80s4Y0DE X-Received: by 2002:a65:4005:: with SMTP id f5-v6mr21926746pgp.302.1531231415074; Tue, 10 Jul 2018 07:03:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531231415; cv=none; d=google.com; s=arc-20160816; b=h/mV9C05ou1S89Kh2Cx245jWTJqiUlwzP1oaUgIVSyxDuENeiDI3zOrvMOGwz1ptyO MPVygtejuAxl5+rs7GTUt5ZZDJasn8GBi12Jzfw2O+lXlBBVgqvKmmdNusYZBSOFD4w8 5pmopKgU2mbn+TNc+CdPBvHjmT4jGbA6tLveWeIvlYC2dN9xIlFKOpDatwK3Na6ICmdo 1pAR0/HxWUMD155T4XzZ4aoM6lul9ttVQKRVsKZa+Wyl1iaV/bzOAhLDXZoJ9LXVyCL5 Gpccrx0qWExRPmtntVehBQgv44wStgpHOhgxsUMcoLiM64+A7WOx0p9Qi4evP9sNI2qM vQjQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=jv9XFl9pFZqxjZgsp89UogN0/rP/faKUPss3dsQYMLQ=; b=LZvpHKJ8zt399c4lDAN7lIY1J21eNJRYc+U6qQJUJWdV/0He/C/Q3qzSMMNBu0r6AO yzx9AlfuAJdQwQHbwIpBRx2OoxZAUR5eEGuwbi17vi8NOpyLx1agIy5CnIs9TqZkfY1L 41Vt8BMFgQ4MP4iC5/dl2W687p1sM837cB/TVZx9lzyhZS6p9RA5dXrGA0iBF8unOuLM jEBaQKEcv4AFdwCTkC+twppAjVpXLhBRJhWUV9b/gFi5lxIuhHlPO/FA2c0OE3seE+NM tq/xA+ncYcJ8el9wa8Nkqvq5O2NuX2PY5znYWCMGqRlpQPiAdk4n1H7kJt2vLJDX42l9 0zmg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=jUdoSEWD; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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. [209.132.180.67]) by mx.google.com with ESMTP id i11-v6si15483781pgs.674.2018.07.10.07.03.19; Tue, 10 Jul 2018 07:03:35 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-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=@kernel.org header.s=default header.b=jUdoSEWD; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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 S933687AbeGJOCE (ORCPT + 99 others); Tue, 10 Jul 2018 10:02:04 -0400 Received: from mail.kernel.org ([198.145.29.99]:34102 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933501AbeGJOBd (ORCPT ); Tue, 10 Jul 2018 10:01:33 -0400 Received: from tleilax.poochiereds.net (cpe-71-70-156-158.nc.res.rr.com [71.70.156.158]) (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 81BC0208E6; Tue, 10 Jul 2018 14:01:32 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1531231293; bh=CrAZ1Nd7UOYLzou0pR5gkpc/2SacGmBjzGXjvBfMpx8=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=jUdoSEWDHeToWF7u27wCe+PRlV/Sc04X/yqIVJ8QkwJ1AiyTzusUN/4Hd0ORBGooA NB1779LWfgC+R4lK/dcBd9SFy3hHoAkWIbBduhDCah1eBhPE6Aub+J+i6pGt+pFQGY Veo1eDuPJEycleG2ZSWfwM1rKpcueY5BnvENvnKQ= From: Jeff Layton To: viro@ZenIV.linux.org.uk, dhowells@redhat.com Cc: willy@infradead.org, andres@anarazel.de, cmaiolino@redhat.com, linux-kernel@vger.kernel.org, linux-fsdevel@vger.kernel.org Subject: [PATCH v2 3/4] vfs: allow fsinfo to fetch the current state of s_wb_err Date: Tue, 10 Jul 2018 10:01:26 -0400 Message-Id: <20180710140127.20739-4-jlayton@kernel.org> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20180710140127.20739-1-jlayton@kernel.org> References: <20180710140127.20739-1-jlayton@kernel.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Jeff Layton Add a new "error_state" struct to fsinfo, and teach the kernel to fill that out from sb->s_wb_info. There are two fields: wb_error_last: the most recently recorded errno for the filesystem wb_error_cookie: this value will change vs. the previously fetched value if a new error was recorded since it was last checked Signed-off-by: Jeff Layton --- fs/statfs.c | 9 +++++++++ include/uapi/linux/fsinfo.h | 11 +++++++++++ 2 files changed, 20 insertions(+) diff --git a/fs/statfs.c b/fs/statfs.c index fa6be965dce1..fb1f48eb381a 100644 --- a/fs/statfs.c +++ b/fs/statfs.c @@ -576,6 +576,14 @@ static int fsinfo_generic_io_size(struct dentry *dentry, return sizeof(*c); } +static int fsinfo_generic_error_state(struct dentry *dentry, + struct fsinfo_error_state *c) +{ + c->wb_error_cookie = errseq_scrape(&dentry->d_sb->s_wb_err); + c->wb_error_last = c->wb_error_cookie & MAX_ERRNO; + return sizeof(*c); +} + /* * Implement some queries generically from stuff in the superblock. */ @@ -594,6 +602,7 @@ int generic_fsinfo(struct dentry *dentry, struct fsinfo_kparams *params) case _gen(volume_id); case _gen(name_encoding); case _gen(io_size); + case _gen(error_state); default: return -EOPNOTSUPP; } diff --git a/include/uapi/linux/fsinfo.h b/include/uapi/linux/fsinfo.h index f2bc5130544d..fbc5d840ea4e 100644 --- a/include/uapi/linux/fsinfo.h +++ b/include/uapi/linux/fsinfo.h @@ -35,6 +35,7 @@ enum fsinfo_attribute { fsinfo_attr_name_encoding = 17, /* Filename encoding (string) */ fsinfo_attr_name_codepage = 18, /* Filename codepage (string) */ fsinfo_attr_io_size = 19, /* Optimal I/O sizes */ + fsinfo_attr_error_state = 20, /* Error state */ fsinfo_attr__nr }; @@ -211,6 +212,16 @@ struct fsinfo_server_address { struct __kernel_sockaddr_storage address; }; +/* + * Information struct for fsinfo(fsinfo_attr_error_state). + * + * Retrieve the error state for a filesystem. + */ +struct fsinfo_error_state { + __u32 wb_error_cookie; /* writeback error cookie */ + __u32 wb_error_last; /* latest writeback error */ +}; + /* * Information struct for fsinfo(fsinfo_attr_io_size). * -- 2.17.1