aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs/disk-io.c
diff options
context:
space:
mode:
authorChris Mason <chris.mason@oracle.com>2009-05-18 10:41:58 -0400
committerChris Mason <chris.mason@oracle.com>2009-06-10 11:29:48 -0400
commit585ad2c3797dcaa643aeba75b9f072778adf3490 (patch)
tree4d48ff8f61f81a84bc620eb59215e1273f788d35 /fs/btrfs/disk-io.c
parent2c943de6ad795a174dcc424c293bb77f15ae3b8c (diff)
Btrfs: fix metadata dirty throttling limits
Once a metadata block has been written, it must be recowed, so the btrfs dirty balancing call has a check to make sure a fair amount of metadata was actually dirty before it started writing it back to disk. A previous commit had changed the dirty tracking for metadata without updating the btrfs dirty balancing checks. This commit switches it to use the correct counter. Signed-off-by: Chris Mason <chris.mason@oracle.com>
Diffstat (limited to 'fs/btrfs/disk-io.c')
-rw-r--r--fs/btrfs/disk-io.c7
1 files changed, 2 insertions, 5 deletions
diff --git a/fs/btrfs/disk-io.c b/fs/btrfs/disk-io.c
index 7f5c6e3e9992..e572cf478a5d 100644
--- a/fs/btrfs/disk-io.c
+++ b/fs/btrfs/disk-io.c
@@ -2378,17 +2378,14 @@ void btrfs_btree_balance_dirty(struct btrfs_root *root, unsigned long nr)
2378 * looks as though older kernels can get into trouble with 2378 * looks as though older kernels can get into trouble with
2379 * this code, they end up stuck in balance_dirty_pages forever 2379 * this code, they end up stuck in balance_dirty_pages forever
2380 */ 2380 */
2381 struct extent_io_tree *tree;
2382 u64 num_dirty; 2381 u64 num_dirty;
2383 u64 start = 0;
2384 unsigned long thresh = 32 * 1024 * 1024; 2382 unsigned long thresh = 32 * 1024 * 1024;
2385 tree = &BTRFS_I(root->fs_info->btree_inode)->io_tree;
2386 2383
2387 if (current->flags & PF_MEMALLOC) 2384 if (current->flags & PF_MEMALLOC)
2388 return; 2385 return;
2389 2386
2390 num_dirty = count_range_bits(tree, &start, (u64)-1, 2387 num_dirty = root->fs_info->dirty_metadata_bytes;
2391 thresh, EXTENT_DIRTY); 2388
2392 if (num_dirty > thresh) { 2389 if (num_dirty > thresh) {
2393 balance_dirty_pages_ratelimited_nr( 2390 balance_dirty_pages_ratelimited_nr(
2394 root->fs_info->btree_inode->i_mapping, 1); 2391 root->fs_info->btree_inode->i_mapping, 1);