Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp4861229iog; Wed, 22 Jun 2022 07:14:34 -0700 (PDT) X-Google-Smtp-Source: AGRyM1te2nvylL6zL8dJM0s2mShKUPF0sxgAADep7OzdDBTN8kMgXYpiSK/3UrvlO9WT+Zou1dKZ X-Received: by 2002:a63:7c49:0:b0:40c:b3f9:18c5 with SMTP id l9-20020a637c49000000b0040cb3f918c5mr3116949pgn.588.1655907274424; Wed, 22 Jun 2022 07:14:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655907274; cv=none; d=google.com; s=arc-20160816; b=QR5o59BmBd8vj8ZanleSf4drM68pqaJv+FehY9GEgQrrHmB6xz52OfYXWTux+O7ZOs TnNznkbb/PhQoN538wBDer3/GC2Z9LHsgWhIpaz5DQ1AkOoemA1i4sfsIoFqD5xJJjTC L0wgCJhrHVYi77PDvbuDm7kG6RlMkiu2Q+dY8xT3S1fG/67UEXnGmDDdRYEJIgetxa/e HDa0ITtxIFYRs4ZVI4LLg2+S5jh4YYdN4MUlnniQl8/lP0Ow3adHe3gRCCJvj8nROehd 9WbJZBqonaMYuYLgprFkA+Vwg1fxLDwxPqJu+h/+EIyy4dUIxTqHp9SIFIS407kX5XbQ q0kQ== 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:message-id:date:cc:to:from :subject; bh=gAQGIBoV6Ze1JI39hvg6fBzJ0igezGxlS52AOxE4lkg=; b=bjmqngCWmRdp5F66RvM8V6eXxa0ArQpvYlBLpd9Di/SmXSIyYAgLwiPsE78txMqJhT 6n/6TjHteDx5YrZLHUBU6Vukk+JUanKPSWarv45UFhPBuqN321sdPgoyy7nU0Xaz0d91 TA7VHuGj2BBjW3QpZzfb8LvHDIK4ojGwwEmehrLEYExenjm2qemzDdIttjics9YKAn6q 6y+l2qBfQm1P9ZvOwQ11UuY7S4lN7HubCzr1niutT9LRaZyj0FbtN/kzpWBSf4nNUrQK XBHQlveh9xUntS+Nd1r45zqFt4+tRvggXrii9y4FOTAOVz/GR6N6GpjNavFoCOfcK65G 7JEQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-nfs-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-nfs-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=oracle.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id h2-20020a170902f54200b00161d4849aa6si25774617plf.390.2022.06.22.07.14.19; Wed, 22 Jun 2022 07:14:34 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-nfs-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-nfs-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-nfs-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=oracle.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1358127AbiFVOOF (ORCPT + 99 others); Wed, 22 Jun 2022 10:14:05 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35792 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1358290AbiFVONs (ORCPT ); Wed, 22 Jun 2022 10:13:48 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D1199BAF; Wed, 22 Jun 2022 07:13:47 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 6BDB561B71; Wed, 22 Jun 2022 14:13:47 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 70DB3C34114; Wed, 22 Jun 2022 14:13:46 +0000 (UTC) Subject: [PATCH RFC 09/30] NFSD: Record number of flush calls From: Chuck Lever To: linux-nfs@vger.kernel.org, netdev@vger.kernel.org Cc: david@fromorbit.com, tgraf@suug.ch, jlayton@redhat.com Date: Wed, 22 Jun 2022 10:13:45 -0400 Message-ID: <165590722535.75778.7826105117559897405.stgit@manet.1015granger.net> In-Reply-To: <165590626293.75778.9843437418112335153.stgit@manet.1015granger.net> References: <165590626293.75778.9843437418112335153.stgit@manet.1015granger.net> User-Agent: StGit/1.5.dev2+g9ce680a5 MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-6.7 required=5.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,RCVD_IN_DNSWL_HI,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-nfs@vger.kernel.org Signed-off-by: Chuck Lever --- fs/nfsd/filecache.c | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/fs/nfsd/filecache.c b/fs/nfsd/filecache.c index d597acfdab28..cae7fa2343c1 100644 --- a/fs/nfsd/filecache.c +++ b/fs/nfsd/filecache.c @@ -45,6 +45,7 @@ struct nfsd_fcache_bucket { static DEFINE_PER_CPU(unsigned long, nfsd_file_cache_hits); static DEFINE_PER_CPU(unsigned long, nfsd_file_acquisitions); static DEFINE_PER_CPU(unsigned long, nfsd_file_releases); +static DEFINE_PER_CPU(unsigned long, nfsd_file_pages_flushed); static DEFINE_PER_CPU(unsigned long, nfsd_file_evictions); struct nfsd_fcache_disposal { @@ -249,7 +250,12 @@ nfsd_file_check_write_error(struct nfsd_file *nf) static void nfsd_file_flush(struct nfsd_file *nf) { - if (nf->nf_file && vfs_fsync(nf->nf_file, 1) != 0) + struct file *file = nf->nf_file; + + if (!file || !(file->f_mode & FMODE_WRITE)) + return; + this_cpu_add(nfsd_file_pages_flushed, file->f_mapping->nrpages); + if (vfs_fsync(file, 1) != 0) nfsd_reset_write_verifier(net_generic(nf->nf_net, nfsd_net_id)); } @@ -1091,7 +1097,8 @@ nfsd_file_create(struct svc_rqst *rqstp, struct svc_fh *fhp, */ static int nfsd_file_cache_stats_show(struct seq_file *m, void *v) { - unsigned long hits = 0, acquisitions = 0, releases = 0, evictions = 0; + unsigned long releases = 0, pages_flushed = 0, evictions = 0; + unsigned long hits = 0, acquisitions = 0; unsigned int i, count = 0, longest = 0; /* @@ -1113,6 +1120,7 @@ static int nfsd_file_cache_stats_show(struct seq_file *m, void *v) acquisitions += per_cpu(nfsd_file_acquisitions, i); releases += per_cpu(nfsd_file_releases, i); evictions += per_cpu(nfsd_file_evictions, i); + pages_flushed += per_cpu(nfsd_file_pages_flushed, i); } seq_printf(m, "total entries: %u\n", count); @@ -1127,6 +1135,7 @@ static int nfsd_file_cache_stats_show(struct seq_file *m, void *v) atomic_long_read(&nfsd_file_total_age) / releases); else seq_printf(m, "mean age (ms): -\n"); + seq_printf(m, "pages flushed: %lu\n", pages_flushed); return 0; }