aboutsummaryrefslogtreecommitdiffstats
path: root/fs/xfs/xfs_mount.h
diff options
context:
space:
mode:
authorDave Chinner <david@fromorbit.com>2015-02-23 05:22:03 -0500
committerDave Chinner <david@fromorbit.com>2015-02-23 05:22:03 -0500
commit0d485ada404b3614b045e574bec26aaf5d9b3c5b (patch)
treeb08812daee1eed9e8be59e6c12bf0eeef5b6f7cf /fs/xfs/xfs_mount.h
parente88b64ea1f3da64dbb52636377be295c90367377 (diff)
xfs: use generic percpu counters for free block counter
XFS has hand-rolled per-cpu counters for the superblock since before there was any generic implementation. The free block counter is special in that it is used for ENOSPC detection outside transaction contexts for for delayed allocation. This means that the counter needs to be accurate at zero. The current per-cpu counter code jumps through lots of hoops to ensure we never run past zero, but we don't need to make all those jumps with the generic counter implementation. The generic counter implementation allows us to pass a "batch" threshold at which the addition/subtraction to the counter value will be folded back into global value under lock. We can use this feature to reduce the batch size as we approach 0 in a very similar manner to the existing counters and their rebalance algorithm. If we use a batch size of 1 as we approach 0, then every addition and subtraction will be done against the global value and hence allow accurate detection of zero threshold crossing. Hence we can replace the handrolled, accurate-at-zero counters with generic percpu counters. Note: this removes just enough of the icsb infrastructure to compile without warnings. The rest will go in subsequent commits. Signed-off-by: Dave Chinner <dchinner@redhat.com> Reviewed-by: Brian Foster <bfoster@redhat.com> Signed-off-by: Dave Chinner <david@fromorbit.com>
Diffstat (limited to 'fs/xfs/xfs_mount.h')
-rw-r--r--fs/xfs/xfs_mount.h3
1 files changed, 3 insertions, 0 deletions
diff --git a/fs/xfs/xfs_mount.h b/fs/xfs/xfs_mount.h
index 7ce997d43d81..84b745fbc787 100644
--- a/fs/xfs/xfs_mount.h
+++ b/fs/xfs/xfs_mount.h
@@ -85,6 +85,7 @@ typedef struct xfs_mount {
85 spinlock_t m_sb_lock; /* sb counter lock */ 85 spinlock_t m_sb_lock; /* sb counter lock */
86 struct percpu_counter m_icount; /* allocated inodes counter */ 86 struct percpu_counter m_icount; /* allocated inodes counter */
87 struct percpu_counter m_ifree; /* free inodes counter */ 87 struct percpu_counter m_ifree; /* free inodes counter */
88 struct percpu_counter m_fdblocks; /* free block counter */
88 89
89 struct xfs_buf *m_sb_bp; /* buffer for superblock */ 90 struct xfs_buf *m_sb_bp; /* buffer for superblock */
90 char *m_fsname; /* filesystem name */ 91 char *m_fsname; /* filesystem name */
@@ -393,6 +394,8 @@ extern int xfs_mod_incore_sb_batch(xfs_mount_t *, xfs_mod_sb_t *,
393 uint, int); 394 uint, int);
394extern int xfs_mod_icount(struct xfs_mount *mp, int64_t delta); 395extern int xfs_mod_icount(struct xfs_mount *mp, int64_t delta);
395extern int xfs_mod_ifree(struct xfs_mount *mp, int64_t delta); 396extern int xfs_mod_ifree(struct xfs_mount *mp, int64_t delta);
397extern int xfs_mod_fdblocks(struct xfs_mount *mp, int64_t delta,
398 bool reserved);
396extern int xfs_mount_log_sb(xfs_mount_t *); 399extern int xfs_mount_log_sb(xfs_mount_t *);
397extern struct xfs_buf *xfs_getsb(xfs_mount_t *, int); 400extern struct xfs_buf *xfs_getsb(xfs_mount_t *, int);
398extern int xfs_readsb(xfs_mount_t *, int); 401extern int xfs_readsb(xfs_mount_t *, int);