xfs: use offsetof() in place of offset macros for __xfsstats
Most offset macro mess is used in xfs_stats_format() only, and we can simply get the right offsets using offsetof(), instead of several macros to mark the offsets inside __xfsstats structure. Replace all XFSSTAT_END_* macros by a single helper macro to get the right offset into __xfsstats, and use this helper in xfs_stats_format() directly. The quota stats code, still looks a bit cleaner when using XFSSTAT_* macros, so, this patch also defines XFSSTAT_START_XQMSTAT and XFSSTAT_END_XQMSTAT locally to that code. This also should prevent offset mistakes when updates are done into __xfsstats. Signed-off-by: Carlos Maiolino <cmaiolino@redhat.com> Reviewed-by: Darrick J. Wong <darrick.wong@oracle.com> Signed-off-by: Dave Chinner <david@fromorbit.com>
This commit is contained in:

committed by
Dave Chinner

parent
41657e5507
commit
26ca39015e
@@ -29,30 +29,30 @@ int xfs_stats_format(struct xfsstats __percpu *stats, char *buf)
|
||||
char *desc;
|
||||
int endpoint;
|
||||
} xstats[] = {
|
||||
{ "extent_alloc", XFSSTAT_END_EXTENT_ALLOC },
|
||||
{ "abt", XFSSTAT_END_ALLOC_BTREE },
|
||||
{ "blk_map", XFSSTAT_END_BLOCK_MAPPING },
|
||||
{ "bmbt", XFSSTAT_END_BLOCK_MAP_BTREE },
|
||||
{ "dir", XFSSTAT_END_DIRECTORY_OPS },
|
||||
{ "trans", XFSSTAT_END_TRANSACTIONS },
|
||||
{ "ig", XFSSTAT_END_INODE_OPS },
|
||||
{ "log", XFSSTAT_END_LOG_OPS },
|
||||
{ "push_ail", XFSSTAT_END_TAIL_PUSHING },
|
||||
{ "xstrat", XFSSTAT_END_WRITE_CONVERT },
|
||||
{ "rw", XFSSTAT_END_READ_WRITE_OPS },
|
||||
{ "attr", XFSSTAT_END_ATTRIBUTE_OPS },
|
||||
{ "icluster", XFSSTAT_END_INODE_CLUSTER },
|
||||
{ "vnodes", XFSSTAT_END_VNODE_OPS },
|
||||
{ "buf", XFSSTAT_END_BUF },
|
||||
{ "abtb2", XFSSTAT_END_ABTB_V2 },
|
||||
{ "abtc2", XFSSTAT_END_ABTC_V2 },
|
||||
{ "bmbt2", XFSSTAT_END_BMBT_V2 },
|
||||
{ "ibt2", XFSSTAT_END_IBT_V2 },
|
||||
{ "fibt2", XFSSTAT_END_FIBT_V2 },
|
||||
{ "rmapbt", XFSSTAT_END_RMAP_V2 },
|
||||
{ "refcntbt", XFSSTAT_END_REFCOUNT },
|
||||
{ "extent_alloc", xfsstats_offset(xs_abt_lookup) },
|
||||
{ "abt", xfsstats_offset(xs_blk_mapr) },
|
||||
{ "blk_map", xfsstats_offset(xs_bmbt_lookup) },
|
||||
{ "bmbt", xfsstats_offset(xs_dir_lookup) },
|
||||
{ "dir", xfsstats_offset(xs_trans_sync) },
|
||||
{ "trans", xfsstats_offset(xs_ig_attempts) },
|
||||
{ "ig", xfsstats_offset(xs_log_writes) },
|
||||
{ "log", xfsstats_offset(xs_try_logspace)},
|
||||
{ "push_ail", xfsstats_offset(xs_xstrat_quick)},
|
||||
{ "xstrat", xfsstats_offset(xs_write_calls) },
|
||||
{ "rw", xfsstats_offset(xs_attr_get) },
|
||||
{ "attr", xfsstats_offset(xs_iflush_count)},
|
||||
{ "icluster", xfsstats_offset(vn_active) },
|
||||
{ "vnodes", xfsstats_offset(xb_get) },
|
||||
{ "buf", xfsstats_offset(xs_abtb_2) },
|
||||
{ "abtb2", xfsstats_offset(xs_abtc_2) },
|
||||
{ "abtc2", xfsstats_offset(xs_bmbt_2) },
|
||||
{ "bmbt2", xfsstats_offset(xs_ibt_2) },
|
||||
{ "ibt2", xfsstats_offset(xs_fibt_2) },
|
||||
{ "fibt2", xfsstats_offset(xs_rmap_2) },
|
||||
{ "rmapbt", xfsstats_offset(xs_refcbt_2) },
|
||||
{ "refcntbt", xfsstats_offset(xs_qm_dqreclaims)},
|
||||
/* we print both series of quota information together */
|
||||
{ "qm", XFSSTAT_END_QM },
|
||||
{ "qm", xfsstats_offset(xs_xstrat_bytes)},
|
||||
};
|
||||
|
||||
/* Loop over all stats groups */
|
||||
@@ -104,6 +104,10 @@ void xfs_stats_clearall(struct xfsstats __percpu *stats)
|
||||
#ifdef CONFIG_PROC_FS
|
||||
/* legacy quota interfaces */
|
||||
#ifdef CONFIG_XFS_QUOTA
|
||||
|
||||
#define XFSSTAT_START_XQMSTAT xfsstats_offset(xs_qm_dqreclaims)
|
||||
#define XFSSTAT_END_XQMSTAT xfsstats_offset(xs_qm_dquot)
|
||||
|
||||
static int xqm_proc_show(struct seq_file *m, void *v)
|
||||
{
|
||||
/* maximum; incore; ratio free to inuse; freelist */
|
||||
@@ -119,7 +123,7 @@ static int xqmstat_proc_show(struct seq_file *m, void *v)
|
||||
int j;
|
||||
|
||||
seq_printf(m, "qm");
|
||||
for (j = XFSSTAT_END_REFCOUNT; j < XFSSTAT_END_XQMSTAT; j++)
|
||||
for (j = XFSSTAT_START_XQMSTAT; j < XFSSTAT_END_XQMSTAT; j++)
|
||||
seq_printf(m, " %u", counter_val(xfsstats.xs_stats, j));
|
||||
seq_putc(m, '\n');
|
||||
return 0;
|
||||
|
Reference in New Issue
Block a user