1*b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */
2d9ef5a8cSChuck Lever /*
3d9ef5a8cSChuck Lever * linux/fs/nfs/iostat.h
4d9ef5a8cSChuck Lever *
5d9ef5a8cSChuck Lever * Declarations for NFS client per-mount statistics
6d9ef5a8cSChuck Lever *
7d9ef5a8cSChuck Lever * Copyright (C) 2005, 2006 Chuck Lever <cel@netapp.com>
8d9ef5a8cSChuck Lever *
9d9ef5a8cSChuck Lever */
10d9ef5a8cSChuck Lever
11d9ef5a8cSChuck Lever #ifndef _NFS_IOSTAT
12d9ef5a8cSChuck Lever #define _NFS_IOSTAT
13d9ef5a8cSChuck Lever
14d9ef5a8cSChuck Lever #include <linux/percpu.h>
15d9ef5a8cSChuck Lever #include <linux/cache.h>
1634e8f928SChuck Lever #include <linux/nfs_iostat.h>
17d9ef5a8cSChuck Lever
18d9ef5a8cSChuck Lever struct nfs_iostats {
19d9ef5a8cSChuck Lever unsigned long long bytes[__NFSIOS_BYTESMAX];
20d9ef5a8cSChuck Lever unsigned long events[__NFSIOS_COUNTSMAX];
21d9ef5a8cSChuck Lever } ____cacheline_aligned;
22d9ef5a8cSChuck Lever
nfs_inc_server_stats(const struct nfs_server * server,enum nfs_stat_eventcounters stat)232e96d286STrond Myklebust static inline void nfs_inc_server_stats(const struct nfs_server *server,
2434e8f928SChuck Lever enum nfs_stat_eventcounters stat)
25d9ef5a8cSChuck Lever {
26fce22848SChristoph Lameter this_cpu_inc(server->io_stats->events[stat]);
27d9ef5a8cSChuck Lever }
28d9ef5a8cSChuck Lever
nfs_inc_stats(const struct inode * inode,enum nfs_stat_eventcounters stat)292e96d286STrond Myklebust static inline void nfs_inc_stats(const struct inode *inode,
3034e8f928SChuck Lever enum nfs_stat_eventcounters stat)
31006ea73eSChuck Lever {
32006ea73eSChuck Lever nfs_inc_server_stats(NFS_SERVER(inode), stat);
33006ea73eSChuck Lever }
34006ea73eSChuck Lever
nfs_add_server_stats(const struct nfs_server * server,enum nfs_stat_bytecounters stat,long addend)352e96d286STrond Myklebust static inline void nfs_add_server_stats(const struct nfs_server *server,
3634e8f928SChuck Lever enum nfs_stat_bytecounters stat,
37dfe52c04SChuck Lever long addend)
38006ea73eSChuck Lever {
39fce22848SChristoph Lameter this_cpu_add(server->io_stats->bytes[stat], addend);
40006ea73eSChuck Lever }
41006ea73eSChuck Lever
nfs_add_stats(const struct inode * inode,enum nfs_stat_bytecounters stat,long addend)422e96d286STrond Myklebust static inline void nfs_add_stats(const struct inode *inode,
4334e8f928SChuck Lever enum nfs_stat_bytecounters stat,
44dfe52c04SChuck Lever long addend)
45d9ef5a8cSChuck Lever {
46006ea73eSChuck Lever nfs_add_server_stats(NFS_SERVER(inode), stat, addend);
47d9ef5a8cSChuck Lever }
48d9ef5a8cSChuck Lever
nfs_alloc_iostats(void)49003cb608STejun Heo static inline struct nfs_iostats __percpu *nfs_alloc_iostats(void)
50d9ef5a8cSChuck Lever {
51d9ef5a8cSChuck Lever return alloc_percpu(struct nfs_iostats);
52d9ef5a8cSChuck Lever }
53d9ef5a8cSChuck Lever
nfs_free_iostats(struct nfs_iostats __percpu * stats)54003cb608STejun Heo static inline void nfs_free_iostats(struct nfs_iostats __percpu *stats)
55d9ef5a8cSChuck Lever {
5601d0ae8bSTrond Myklebust if (stats != NULL)
57d9ef5a8cSChuck Lever free_percpu(stats);
58d9ef5a8cSChuck Lever }
59d9ef5a8cSChuck Lever
6034e8f928SChuck Lever #endif /* _NFS_IOSTAT */
61