diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2009-05-17 11:44:19 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-05-17 11:44:19 -0700 |
commit | bba0b4ec3cd6c52cb778af34ad70f6cc3aec1c7e (patch) | |
tree | d065f4b4d74992cc02fdb91fa54bb9c9d6ca213c /mm/slob.c | |
parent | 0f6f49a8cd0163fdb1723ed29f01fc65177108dc (diff) | |
parent | 42ddc4cbbad1b87b00e00095305d61cc248c2305 (diff) | |
download | linux-bba0b4ec3cd6c52cb778af34ad70f6cc3aec1c7e.tar.gz linux-bba0b4ec3cd6c52cb778af34ad70f6cc3aec1c7e.tar.bz2 linux-bba0b4ec3cd6c52cb778af34ad70f6cc3aec1c7e.zip |
Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/penberg/slab-2.6
* 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/penberg/slab-2.6:
mm: SLOB fix reclaim_state
mm: SLUB fix reclaim_state
slub: add Documentation/ABI/testing/sysfs-kernel-slab
slub: enforce MAX_ORDER
Diffstat (limited to 'mm/slob.c')
-rw-r--r-- | mm/slob.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/mm/slob.c b/mm/slob.c index a2d4ab32198d..f92e66d558bd 100644 --- a/mm/slob.c +++ b/mm/slob.c @@ -60,6 +60,7 @@ #include <linux/kernel.h> #include <linux/slab.h> #include <linux/mm.h> +#include <linux/swap.h> /* struct reclaim_state */ #include <linux/cache.h> #include <linux/init.h> #include <linux/module.h> @@ -255,6 +256,8 @@ static void *slob_new_pages(gfp_t gfp, int order, int node) static void slob_free_pages(void *b, int order) { + if (current->reclaim_state) + current->reclaim_state->reclaimed_slab += 1 << order; free_pages((unsigned long)b, order); } @@ -407,7 +410,7 @@ static void slob_free(void *block, int size) spin_unlock_irqrestore(&slob_lock, flags); clear_slob_page(sp); free_slob_page(sp); - free_page((unsigned long)b); + slob_free_pages(b, 0); return; } |