Re: [PATCH] [RFC] xfs: make xfs btree stats less huge

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, Sep 20, 2016 at 03:59:45PM +1000, Dave Chinner wrote:
> On Mon, Sep 19, 2016 at 09:16:52PM -0700, Darrick J. Wong wrote:
> > On Tue, Sep 13, 2016 at 06:28:42PM +1000, Dave Chinner wrote:
> > > -	__uint32_t		xs_rmap_2_decrement;
> > > -	__uint32_t		xs_rmap_2_lshift;
> > > -	__uint32_t		xs_rmap_2_rshift;
> > > -	__uint32_t		xs_rmap_2_split;
> > > -	__uint32_t		xs_rmap_2_join;
> > > -	__uint32_t		xs_rmap_2_alloc;
> > > -	__uint32_t		xs_rmap_2_free;
> > > -	__uint32_t		xs_rmap_2_moves;
> > > +#define XFSSTAT_END_ABTB_V2		(XFSSTAT_END_BUF+__XBTS_MAX)
> > > +	__uint32_t		xs_abtb_2[__XBTS_MAX];
> > > +#define XFSSTAT_END_ABTC_V2		(XFSSTAT_END_ABTB_V2+__XBTS_MAX)
> > > +	__uint32_t		xs_abtc_2[__XBTS_MAX];
> > > +#define XFSSTAT_END_BMBT_V2		(XFSSTAT_END_ABTC_V2+__XBTS_MAX)
> > > +	__uint32_t		xs_bmbt_2[__XBTS_MAX];
> > > +#define XFSSTAT_END_IBT_V2		(XFSSTAT_END_BMBT_V2+__XBTS_MAX)
> > > +	__uint32_t		xs_ibt_2[__XBTS_MAX];
> > > +#define XFSSTAT_END_FIBT_V2		(XFSSTAT_END_IBT_V2+__XBTS_MAX)
> > > +	__uint32_t		xs_fibt_2[__XBTS_MAX];
> > > +#define XFSSTAT_END_RMAP_V2		(XFSSTAT_END_FIBT_V2+__XBTS_MAX)
> > > +	__uint32_t		xs_rmap_2[__XBTS_MAX];
> > 
> > Are you planning to merge this before or after the refcount btree?
> 
> Doesn't matter - either way I'll fix up one of them on merge into
> the for-next tree...
> 
> > 
> > >  #define XFSSTAT_END_XQMSTAT		(XFSSTAT_END_RMAP_V2+6)
> > >  	__uint32_t		xs_qm_dqreclaims;
> > >  	__uint32_t		xs_qm_dqreclaim_misses;
> > > @@ -229,26 +165,58 @@ struct xfsstats {
> > >  	__uint64_t		xs_read_bytes;
> > >  };
> > >  
> > > +struct xfsstats {
> > > +	union {
> > > +		struct __xfsstats	s;
> > > +		uint32_t		a[XFSSTAT_END_XQMSTAT];
> > > +	};
> > 
> > /me wonders if there ought to be a build time check to make sure that
> > these two are really the same size?  They look all right as is, but
> > I can see myself forgetting to change something and screwing it up. :(
> 
> It isn't the same size, because struct __xfsstats has three u64
> stats at the end that aren't part of the u32 array indexed by
> XFSSTAT_END_XQMSTAT. If we get the calculation of
> XFSSTAT_END_XQMSTAT wrong , then the output of the stats in the proc
> and sysfs files is screwed up because it treats the stats as an
> array of u32 items of that same size.  So it's fairly obvious when
> it gets broken...

Well ok, how about a build time check that the sizes are off by exactly how
much we expect them to be?  I guess I'd eventually notice the /proc output
looking weird after staring at bad numbers for long enough... ;)

<shrug> Your call though. :)

--D

> 
> Cheers,
> 
> Dave.
> -- 
> Dave Chinner
> david@xxxxxxxxxxxxx
> --
> To unsubscribe from this list: send the line "unsubscribe linux-xfs" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
--
To unsubscribe from this list: send the line "unsubscribe linux-xfs" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [XFS Filesystem Development (older mail)]     [Linux Filesystem Development]     [Linux Audio Users]     [Yosemite Trails]     [Linux Kernel]     [Linux RAID]     [Linux SCSI]


  Powered by Linux