diff options
author | Brian Foster <bfoster@redhat.com> | 2015-05-29 02:04:19 +0300 |
---|---|---|
committer | Dave Chinner <david@fromorbit.com> | 2015-05-29 02:04:19 +0300 |
commit | 12d0714d4bdd591d9cd3bce692c831da2c2a0cfc (patch) | |
tree | 5e919645cc4dc59b1571dfdaa81b5b9eb9bd8512 /fs/ntfs/Makefile | |
parent | 5419040fc0f3afc31c857b4d7f006bd9afbdb462 (diff) | |
download | linux-12d0714d4bdd591d9cd3bce692c831da2c2a0cfc.tar.xz |
xfs: use actual inode count for sparse records in bulkstat/inumbers
The bulkstat and inumbers mechanisms make the assumption that inode
records consist of a full 64 inode chunk in several places. For example,
this is used to track how many inodes have been processed overall as
well as to determine whether a record has allocated inodes that must be
handled.
This assumption is invalid for sparse inode records. While sparse inodes
will be marked as free in the ir_free mask, they are not accounted as
free in ir_freecount because they cannot be allocated. Therefore,
ir_freecount may be less than 64 inodes in an inode record for which all
physically allocated inodes are free (and in turn ir_freecount < 64 does
not signify that the record has allocated inodes).
The new in-core inobt record format includes the ir_count field. This
holds the number of true, physical inodes tracked by the record. The
in-core ir_count field is always valid as it is hardcoded to
XFS_INODES_PER_CHUNK when sparse inodes is not enabled. Use ir_count to
handle inode records correctly in bulkstat in a generic manner.
Signed-off-by: Brian Foster <bfoster@redhat.com>
Reviewed-by: Dave Chinner <dchinner@redhat.com>
Signed-off-by: Dave Chinner <david@fromorbit.com>
Diffstat (limited to 'fs/ntfs/Makefile')
0 files changed, 0 insertions, 0 deletions