162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Statistics for NFS server.
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Copyright (C) 1995, 1996 Olaf Kirch <okir@monad.swb.de>
662306a36Sopenharmony_ci */
762306a36Sopenharmony_ci#ifndef _NFSD_STATS_H
862306a36Sopenharmony_ci#define _NFSD_STATS_H
962306a36Sopenharmony_ci
1062306a36Sopenharmony_ci#include <uapi/linux/nfsd/stats.h>
1162306a36Sopenharmony_ci#include <linux/percpu_counter.h>
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ci
1462306a36Sopenharmony_cienum {
1562306a36Sopenharmony_ci	NFSD_STATS_RC_HITS,		/* repcache hits */
1662306a36Sopenharmony_ci	NFSD_STATS_RC_MISSES,		/* repcache misses */
1762306a36Sopenharmony_ci	NFSD_STATS_RC_NOCACHE,		/* uncached reqs */
1862306a36Sopenharmony_ci	NFSD_STATS_FH_STALE,		/* FH stale error */
1962306a36Sopenharmony_ci	NFSD_STATS_IO_READ,		/* bytes returned to read requests */
2062306a36Sopenharmony_ci	NFSD_STATS_IO_WRITE,		/* bytes passed in write requests */
2162306a36Sopenharmony_ci#ifdef CONFIG_NFSD_V4
2262306a36Sopenharmony_ci	NFSD_STATS_FIRST_NFS4_OP,	/* count of individual nfsv4 operations */
2362306a36Sopenharmony_ci	NFSD_STATS_LAST_NFS4_OP = NFSD_STATS_FIRST_NFS4_OP + LAST_NFS4_OP,
2462306a36Sopenharmony_ci#define NFSD_STATS_NFS4_OP(op)	(NFSD_STATS_FIRST_NFS4_OP + (op))
2562306a36Sopenharmony_ci	NFSD_STATS_WDELEG_GETATTR,	/* count of getattr conflict with wdeleg */
2662306a36Sopenharmony_ci#endif
2762306a36Sopenharmony_ci	NFSD_STATS_COUNTERS_NUM
2862306a36Sopenharmony_ci};
2962306a36Sopenharmony_ci
3062306a36Sopenharmony_cistruct nfsd_stats {
3162306a36Sopenharmony_ci	struct percpu_counter	counter[NFSD_STATS_COUNTERS_NUM];
3262306a36Sopenharmony_ci
3362306a36Sopenharmony_ci	atomic_t	th_cnt;		/* number of available threads */
3462306a36Sopenharmony_ci};
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_ciextern struct nfsd_stats	nfsdstats;
3762306a36Sopenharmony_ci
3862306a36Sopenharmony_ciextern struct svc_stat		nfsd_svcstats;
3962306a36Sopenharmony_ci
4062306a36Sopenharmony_ciint nfsd_percpu_counters_init(struct percpu_counter counters[], int num);
4162306a36Sopenharmony_civoid nfsd_percpu_counters_reset(struct percpu_counter counters[], int num);
4262306a36Sopenharmony_civoid nfsd_percpu_counters_destroy(struct percpu_counter counters[], int num);
4362306a36Sopenharmony_ciint nfsd_stat_init(void);
4462306a36Sopenharmony_civoid nfsd_stat_shutdown(void);
4562306a36Sopenharmony_ci
4662306a36Sopenharmony_cistatic inline void nfsd_stats_rc_hits_inc(void)
4762306a36Sopenharmony_ci{
4862306a36Sopenharmony_ci	percpu_counter_inc(&nfsdstats.counter[NFSD_STATS_RC_HITS]);
4962306a36Sopenharmony_ci}
5062306a36Sopenharmony_ci
5162306a36Sopenharmony_cistatic inline void nfsd_stats_rc_misses_inc(void)
5262306a36Sopenharmony_ci{
5362306a36Sopenharmony_ci	percpu_counter_inc(&nfsdstats.counter[NFSD_STATS_RC_MISSES]);
5462306a36Sopenharmony_ci}
5562306a36Sopenharmony_ci
5662306a36Sopenharmony_cistatic inline void nfsd_stats_rc_nocache_inc(void)
5762306a36Sopenharmony_ci{
5862306a36Sopenharmony_ci	percpu_counter_inc(&nfsdstats.counter[NFSD_STATS_RC_NOCACHE]);
5962306a36Sopenharmony_ci}
6062306a36Sopenharmony_ci
6162306a36Sopenharmony_cistatic inline void nfsd_stats_fh_stale_inc(struct svc_export *exp)
6262306a36Sopenharmony_ci{
6362306a36Sopenharmony_ci	percpu_counter_inc(&nfsdstats.counter[NFSD_STATS_FH_STALE]);
6462306a36Sopenharmony_ci	if (exp)
6562306a36Sopenharmony_ci		percpu_counter_inc(&exp->ex_stats.counter[EXP_STATS_FH_STALE]);
6662306a36Sopenharmony_ci}
6762306a36Sopenharmony_ci
6862306a36Sopenharmony_cistatic inline void nfsd_stats_io_read_add(struct svc_export *exp, s64 amount)
6962306a36Sopenharmony_ci{
7062306a36Sopenharmony_ci	percpu_counter_add(&nfsdstats.counter[NFSD_STATS_IO_READ], amount);
7162306a36Sopenharmony_ci	if (exp)
7262306a36Sopenharmony_ci		percpu_counter_add(&exp->ex_stats.counter[EXP_STATS_IO_READ], amount);
7362306a36Sopenharmony_ci}
7462306a36Sopenharmony_ci
7562306a36Sopenharmony_cistatic inline void nfsd_stats_io_write_add(struct svc_export *exp, s64 amount)
7662306a36Sopenharmony_ci{
7762306a36Sopenharmony_ci	percpu_counter_add(&nfsdstats.counter[NFSD_STATS_IO_WRITE], amount);
7862306a36Sopenharmony_ci	if (exp)
7962306a36Sopenharmony_ci		percpu_counter_add(&exp->ex_stats.counter[EXP_STATS_IO_WRITE], amount);
8062306a36Sopenharmony_ci}
8162306a36Sopenharmony_ci
8262306a36Sopenharmony_cistatic inline void nfsd_stats_payload_misses_inc(struct nfsd_net *nn)
8362306a36Sopenharmony_ci{
8462306a36Sopenharmony_ci	percpu_counter_inc(&nn->counter[NFSD_NET_PAYLOAD_MISSES]);
8562306a36Sopenharmony_ci}
8662306a36Sopenharmony_ci
8762306a36Sopenharmony_cistatic inline void nfsd_stats_drc_mem_usage_add(struct nfsd_net *nn, s64 amount)
8862306a36Sopenharmony_ci{
8962306a36Sopenharmony_ci	percpu_counter_add(&nn->counter[NFSD_NET_DRC_MEM_USAGE], amount);
9062306a36Sopenharmony_ci}
9162306a36Sopenharmony_ci
9262306a36Sopenharmony_cistatic inline void nfsd_stats_drc_mem_usage_sub(struct nfsd_net *nn, s64 amount)
9362306a36Sopenharmony_ci{
9462306a36Sopenharmony_ci	percpu_counter_sub(&nn->counter[NFSD_NET_DRC_MEM_USAGE], amount);
9562306a36Sopenharmony_ci}
9662306a36Sopenharmony_ci
9762306a36Sopenharmony_ci#ifdef CONFIG_NFSD_V4
9862306a36Sopenharmony_cistatic inline void nfsd_stats_wdeleg_getattr_inc(void)
9962306a36Sopenharmony_ci{
10062306a36Sopenharmony_ci	percpu_counter_inc(&nfsdstats.counter[NFSD_STATS_WDELEG_GETATTR]);
10162306a36Sopenharmony_ci}
10262306a36Sopenharmony_ci#endif
10362306a36Sopenharmony_ci#endif /* _NFSD_STATS_H */
104