xref: /linux/fs/nfs/iostat.h (revision a1ff5a7d78a036d6c2178ee5acd6ba4946243800)
1b2441318SGreg 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 
49*3b0ba54dSSuren Baghdasaryan /*
50*3b0ba54dSSuren Baghdasaryan  * This specialized allocator has to be a macro for its allocations to be
51*3b0ba54dSSuren Baghdasaryan  * accounted separately (to have a separate alloc_tag).
52*3b0ba54dSSuren Baghdasaryan  */
532c321f3fSSuren Baghdasaryan #define nfs_alloc_iostats()	alloc_percpu(struct nfs_iostats)
54d9ef5a8cSChuck Lever 
nfs_free_iostats(struct nfs_iostats __percpu * stats)55003cb608STejun Heo static inline void nfs_free_iostats(struct nfs_iostats __percpu *stats)
56d9ef5a8cSChuck Lever {
5701d0ae8bSTrond Myklebust 	if (stats != NULL)
58d9ef5a8cSChuck Lever 		free_percpu(stats);
59d9ef5a8cSChuck Lever }
60d9ef5a8cSChuck Lever 
6134e8f928SChuck Lever #endif /* _NFS_IOSTAT */
62