Allow extent_buffers to use more ram
authorChris Mason <chris.mason@oracle.com>
Mon, 6 Feb 2012 10:06:18 +0000 (05:06 -0500)
committerChris Mason <chris.mason@oracle.com>
Mon, 6 Feb 2012 10:08:06 +0000 (05:08 -0500)
This changes free_some_buffers (called each time we allocate an extent
buffer) to allow a higher hard limit on the number of extent buffers
in use.

Signed-off-by: Chris Mason <chris.mason@oracle.com>
extent_io.c

index 9990338b4c700c3f4121948bba32a1352abeac75..ebb35b28c44e98547adc2d61877686e8b29419fb 100644 (file)
@@ -28,7 +28,8 @@
 #include "extent_io.h"
 #include "list.h"
 
-u64 cache_max = 1024 * 1024 * 32;
+u64 cache_soft_max = 1024 * 1024 * 256;
+u64 cache_hard_max = 1 * 1024 * 1024 * 1024;
 
 void extent_io_tree_init(struct extent_io_tree *tree)
 {
@@ -540,18 +541,19 @@ static int free_some_buffers(struct extent_io_tree *tree)
        struct extent_buffer *eb;
        struct list_head *node, *next;
 
-       if (tree->cache_size < cache_max)
+       if (tree->cache_size < cache_soft_max)
                return 0;
+
        list_for_each_safe(node, next, &tree->lru) {
                eb = list_entry(node, struct extent_buffer, lru);
                if (eb->refs == 1) {
                        free_extent_buffer(eb);
-                       if (tree->cache_size < cache_max)
+                       if (tree->cache_size < cache_hard_max)
                                break;
                } else {
                        list_move_tail(&eb->lru, &tree->lru);
                }
-               if (nrscan++ > 64)
+               if (nrscan++ > 64 && tree->cache_size < cache_hard_max)
                        break;
        }
        return 0;