blob: 130db070e4d8a9ae0ad22b89d85cdd3eb3255f7e [file] [log] [blame]
Dave Chinner0b61f8a2018-06-05 19:42:14 -07001// SPDX-License-Identifier: GPL-2.0
Linus Torvalds1da177e2005-04-16 15:20:36 -07002/*
Nathan Scott7b718762005-11-02 14:58:39 +11003 * Copyright (c) 2000,2005 Silicon Graphics, Inc.
4 * All Rights Reserved.
Linus Torvalds1da177e2005-04-16 15:20:36 -07005 */
6#ifndef __XFS_STATS_H__
7#define __XFS_STATS_H__
8
Linus Torvalds1da177e2005-04-16 15:20:36 -07009
10#include <linux/percpu.h>
11
12/*
Dave Chinner11ef38a2016-12-05 14:38:58 +110013 * The btree stats arrays have fixed offsets for the different stats. We
14 * store the base index in the btree cursor via XFS_STATS_CALC_INDEX() and
15 * that allows us to use fixed offsets into the stats array for each btree
16 * stat. These index offsets are defined in the order they will be emitted
17 * in the stats files, so it is possible to add new btree stat types by
18 * appending to the enum list below.
19 */
20enum {
21 __XBTS_lookup = 0,
22 __XBTS_compare = 1,
23 __XBTS_insrec = 2,
24 __XBTS_delrec = 3,
25 __XBTS_newroot = 4,
26 __XBTS_killroot = 5,
27 __XBTS_increment = 6,
28 __XBTS_decrement = 7,
29 __XBTS_lshift = 8,
30 __XBTS_rshift = 9,
31 __XBTS_split = 10,
32 __XBTS_join = 11,
33 __XBTS_alloc = 12,
34 __XBTS_free = 13,
35 __XBTS_moves = 14,
36
37 __XBTS_MAX = 15,
38};
39
40/*
Linus Torvalds1da177e2005-04-16 15:20:36 -070041 * XFS global statistics
42 */
Dave Chinner11ef38a2016-12-05 14:38:58 +110043struct __xfsstats {
Linus Torvalds1da177e2005-04-16 15:20:36 -070044# define XFSSTAT_END_EXTENT_ALLOC 4
Darrick J. Wongc8ce5402017-06-16 11:00:05 -070045 uint32_t xs_allocx;
46 uint32_t xs_allocb;
47 uint32_t xs_freex;
48 uint32_t xs_freeb;
Linus Torvalds1da177e2005-04-16 15:20:36 -070049# define XFSSTAT_END_ALLOC_BTREE (XFSSTAT_END_EXTENT_ALLOC+4)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -070050 uint32_t xs_abt_lookup;
51 uint32_t xs_abt_compare;
52 uint32_t xs_abt_insrec;
53 uint32_t xs_abt_delrec;
Linus Torvalds1da177e2005-04-16 15:20:36 -070054# define XFSSTAT_END_BLOCK_MAPPING (XFSSTAT_END_ALLOC_BTREE+7)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -070055 uint32_t xs_blk_mapr;
56 uint32_t xs_blk_mapw;
57 uint32_t xs_blk_unmap;
58 uint32_t xs_add_exlist;
59 uint32_t xs_del_exlist;
60 uint32_t xs_look_exlist;
61 uint32_t xs_cmp_exlist;
Linus Torvalds1da177e2005-04-16 15:20:36 -070062# define XFSSTAT_END_BLOCK_MAP_BTREE (XFSSTAT_END_BLOCK_MAPPING+4)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -070063 uint32_t xs_bmbt_lookup;
64 uint32_t xs_bmbt_compare;
65 uint32_t xs_bmbt_insrec;
66 uint32_t xs_bmbt_delrec;
Linus Torvalds1da177e2005-04-16 15:20:36 -070067# define XFSSTAT_END_DIRECTORY_OPS (XFSSTAT_END_BLOCK_MAP_BTREE+4)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -070068 uint32_t xs_dir_lookup;
69 uint32_t xs_dir_create;
70 uint32_t xs_dir_remove;
71 uint32_t xs_dir_getdents;
Linus Torvalds1da177e2005-04-16 15:20:36 -070072# define XFSSTAT_END_TRANSACTIONS (XFSSTAT_END_DIRECTORY_OPS+3)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -070073 uint32_t xs_trans_sync;
74 uint32_t xs_trans_async;
75 uint32_t xs_trans_empty;
Linus Torvalds1da177e2005-04-16 15:20:36 -070076# define XFSSTAT_END_INODE_OPS (XFSSTAT_END_TRANSACTIONS+7)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -070077 uint32_t xs_ig_attempts;
78 uint32_t xs_ig_found;
79 uint32_t xs_ig_frecycle;
80 uint32_t xs_ig_missed;
81 uint32_t xs_ig_dup;
82 uint32_t xs_ig_reclaims;
83 uint32_t xs_ig_attrchg;
Linus Torvalds1da177e2005-04-16 15:20:36 -070084# define XFSSTAT_END_LOG_OPS (XFSSTAT_END_INODE_OPS+5)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -070085 uint32_t xs_log_writes;
86 uint32_t xs_log_blocks;
87 uint32_t xs_log_noiclogs;
88 uint32_t xs_log_force;
89 uint32_t xs_log_force_sleep;
Linus Torvalds1da177e2005-04-16 15:20:36 -070090# define XFSSTAT_END_TAIL_PUSHING (XFSSTAT_END_LOG_OPS+10)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -070091 uint32_t xs_try_logspace;
92 uint32_t xs_sleep_logspace;
93 uint32_t xs_push_ail;
94 uint32_t xs_push_ail_success;
95 uint32_t xs_push_ail_pushbuf;
96 uint32_t xs_push_ail_pinned;
97 uint32_t xs_push_ail_locked;
98 uint32_t xs_push_ail_flushing;
99 uint32_t xs_push_ail_restarts;
100 uint32_t xs_push_ail_flush;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700101# define XFSSTAT_END_WRITE_CONVERT (XFSSTAT_END_TAIL_PUSHING+2)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -0700102 uint32_t xs_xstrat_quick;
103 uint32_t xs_xstrat_split;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700104# define XFSSTAT_END_READ_WRITE_OPS (XFSSTAT_END_WRITE_CONVERT+2)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -0700105 uint32_t xs_write_calls;
106 uint32_t xs_read_calls;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700107# define XFSSTAT_END_ATTRIBUTE_OPS (XFSSTAT_END_READ_WRITE_OPS+4)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -0700108 uint32_t xs_attr_get;
109 uint32_t xs_attr_set;
110 uint32_t xs_attr_remove;
111 uint32_t xs_attr_list;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700112# define XFSSTAT_END_INODE_CLUSTER (XFSSTAT_END_ATTRIBUTE_OPS+3)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -0700113 uint32_t xs_iflush_count;
114 uint32_t xs_icluster_flushcnt;
115 uint32_t xs_icluster_flushinode;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700116# define XFSSTAT_END_VNODE_OPS (XFSSTAT_END_INODE_CLUSTER+8)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -0700117 uint32_t vn_active; /* # vnodes not on free lists */
118 uint32_t vn_alloc; /* # times vn_alloc called */
119 uint32_t vn_get; /* # times vn_get called */
120 uint32_t vn_hold; /* # times vn_hold called */
121 uint32_t vn_rele; /* # times vn_rele called */
122 uint32_t vn_reclaim; /* # times vn_reclaim called */
123 uint32_t vn_remove; /* # times vn_remove called */
124 uint32_t vn_free; /* # times vn_free called */
Linus Torvalds1da177e2005-04-16 15:20:36 -0700125#define XFSSTAT_END_BUF (XFSSTAT_END_VNODE_OPS+9)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -0700126 uint32_t xb_get;
127 uint32_t xb_create;
128 uint32_t xb_get_locked;
129 uint32_t xb_get_locked_waited;
130 uint32_t xb_busy_locked;
131 uint32_t xb_miss_locked;
132 uint32_t xb_page_retries;
133 uint32_t xb_page_found;
134 uint32_t xb_get_read;
David Chinner854929f2008-10-30 16:55:03 +1100135/* Version 2 btree counters */
Dave Chinner11ef38a2016-12-05 14:38:58 +1100136#define XFSSTAT_END_ABTB_V2 (XFSSTAT_END_BUF + __XBTS_MAX)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -0700137 uint32_t xs_abtb_2[__XBTS_MAX];
Dave Chinner11ef38a2016-12-05 14:38:58 +1100138#define XFSSTAT_END_ABTC_V2 (XFSSTAT_END_ABTB_V2 + __XBTS_MAX)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -0700139 uint32_t xs_abtc_2[__XBTS_MAX];
Dave Chinner11ef38a2016-12-05 14:38:58 +1100140#define XFSSTAT_END_BMBT_V2 (XFSSTAT_END_ABTC_V2 + __XBTS_MAX)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -0700141 uint32_t xs_bmbt_2[__XBTS_MAX];
Dave Chinner11ef38a2016-12-05 14:38:58 +1100142#define XFSSTAT_END_IBT_V2 (XFSSTAT_END_BMBT_V2 + __XBTS_MAX)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -0700143 uint32_t xs_ibt_2[__XBTS_MAX];
Dave Chinner11ef38a2016-12-05 14:38:58 +1100144#define XFSSTAT_END_FIBT_V2 (XFSSTAT_END_IBT_V2 + __XBTS_MAX)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -0700145 uint32_t xs_fibt_2[__XBTS_MAX];
Dave Chinner11ef38a2016-12-05 14:38:58 +1100146#define XFSSTAT_END_RMAP_V2 (XFSSTAT_END_FIBT_V2 + __XBTS_MAX)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -0700147 uint32_t xs_rmap_2[__XBTS_MAX];
Dave Chinner11ef38a2016-12-05 14:38:58 +1100148#define XFSSTAT_END_REFCOUNT (XFSSTAT_END_RMAP_V2 + __XBTS_MAX)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -0700149 uint32_t xs_refcbt_2[__XBTS_MAX];
Darrick J. Wong46eeb522016-10-03 09:11:16 -0700150#define XFSSTAT_END_XQMSTAT (XFSSTAT_END_REFCOUNT + 6)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -0700151 uint32_t xs_qm_dqreclaims;
152 uint32_t xs_qm_dqreclaim_misses;
153 uint32_t xs_qm_dquot_dups;
154 uint32_t xs_qm_dqcachemisses;
155 uint32_t xs_qm_dqcachehits;
156 uint32_t xs_qm_dqwants;
Christoph Hellwig48776fd2012-03-13 08:52:33 +0000157#define XFSSTAT_END_QM (XFSSTAT_END_XQMSTAT+2)
Darrick J. Wongc8ce5402017-06-16 11:00:05 -0700158 uint32_t xs_qm_dquot;
159 uint32_t xs_qm_dquot_unused;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700160/* Extra precision counters */
Darrick J. Wongc8ce5402017-06-16 11:00:05 -0700161 uint64_t xs_xstrat_bytes;
162 uint64_t xs_write_bytes;
163 uint64_t xs_read_bytes;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700164};
165
Dave Chinner11ef38a2016-12-05 14:38:58 +1100166struct xfsstats {
167 union {
168 struct __xfsstats s;
169 uint32_t a[XFSSTAT_END_XQMSTAT];
170 };
171};
172
173/*
174 * simple wrapper for getting the array index of s struct member offset
175 */
176#define XFS_STATS_CALC_INDEX(member) \
Darrick J. Wongc8ce5402017-06-16 11:00:05 -0700177 (offsetof(struct __xfsstats, member) / (int)sizeof(uint32_t))
Dave Chinner11ef38a2016-12-05 14:38:58 +1100178
179
Bill O'Donnell80529c42015-10-12 05:19:45 +1100180int xfs_stats_format(struct xfsstats __percpu *stats, char *buf);
181void xfs_stats_clearall(struct xfsstats __percpu *stats);
182extern struct xstats xfsstats;
Linus Torvalds1da177e2005-04-16 15:20:36 -0700183
Bill O'Donnellff6d6af2015-10-12 18:21:22 +1100184#define XFS_STATS_INC(mp, v) \
185do { \
Dave Chinner11ef38a2016-12-05 14:38:58 +1100186 per_cpu_ptr(xfsstats.xs_stats, current_cpu())->s.v++; \
187 per_cpu_ptr(mp->m_stats.xs_stats, current_cpu())->s.v++; \
Bill O'Donnellff6d6af2015-10-12 18:21:22 +1100188} while (0)
Bill O'Donnell80529c42015-10-12 05:19:45 +1100189
Bill O'Donnellff6d6af2015-10-12 18:21:22 +1100190#define XFS_STATS_DEC(mp, v) \
191do { \
Dave Chinner11ef38a2016-12-05 14:38:58 +1100192 per_cpu_ptr(xfsstats.xs_stats, current_cpu())->s.v--; \
193 per_cpu_ptr(mp->m_stats.xs_stats, current_cpu())->s.v--; \
Bill O'Donnellff6d6af2015-10-12 18:21:22 +1100194} while (0)
Bill O'Donnell80529c42015-10-12 05:19:45 +1100195
Bill O'Donnellff6d6af2015-10-12 18:21:22 +1100196#define XFS_STATS_ADD(mp, v, inc) \
197do { \
Dave Chinner11ef38a2016-12-05 14:38:58 +1100198 per_cpu_ptr(xfsstats.xs_stats, current_cpu())->s.v += (inc); \
199 per_cpu_ptr(mp->m_stats.xs_stats, current_cpu())->s.v += (inc); \
200} while (0)
201
202#define XFS_STATS_INC_OFF(mp, off) \
203do { \
204 per_cpu_ptr(xfsstats.xs_stats, current_cpu())->a[off]++; \
205 per_cpu_ptr(mp->m_stats.xs_stats, current_cpu())->a[off]++; \
206} while (0)
207
208#define XFS_STATS_DEC_OFF(mp, off) \
209do { \
210 per_cpu_ptr(xfsstats.xs_stats, current_cpu())->a[off]; \
211 per_cpu_ptr(mp->m_stats.xs_stats, current_cpu())->a[off]; \
212} while (0)
213
214#define XFS_STATS_ADD_OFF(mp, off, inc) \
215do { \
216 per_cpu_ptr(xfsstats.xs_stats, current_cpu())->a[off] += (inc); \
217 per_cpu_ptr(mp->m_stats.xs_stats, current_cpu())->a[off] += (inc); \
Bill O'Donnellff6d6af2015-10-12 18:21:22 +1100218} while (0)
219
220#if defined(CONFIG_PROC_FS)
Linus Torvalds1da177e2005-04-16 15:20:36 -0700221
Christoph Hellwig9f8868f2008-07-18 17:11:46 +1000222extern int xfs_init_procfs(void);
Linus Torvalds1da177e2005-04-16 15:20:36 -0700223extern void xfs_cleanup_procfs(void);
224
225
226#else /* !CONFIG_PROC_FS */
227
Christoph Hellwig9f8868f2008-07-18 17:11:46 +1000228static inline int xfs_init_procfs(void)
229{
Christoph Hellwig766b0922008-07-18 17:12:50 +1000230 return 0;
231}
232
Christoph Hellwig9f8868f2008-07-18 17:11:46 +1000233static inline void xfs_cleanup_procfs(void)
234{
Christoph Hellwig766b0922008-07-18 17:12:50 +1000235}
Linus Torvalds1da177e2005-04-16 15:20:36 -0700236
237#endif /* !CONFIG_PROC_FS */
238
239#endif /* __XFS_STATS_H__ */