diff options
author | Thomas Gleixner <tglx@linutronix.de> | 2011-06-20 10:42:04 +0200 |
---|---|---|
committer | Clark Williams <williams@redhat.com> | 2011-12-28 16:25:24 -0600 |
commit | 6ffe7b00db34e9fc247cf6e6701611e0b70e27ce (patch) | |
tree | cb63ad5330535fd2ee2f99beb6a66bafa7a28a37 | |
parent | 8423cdcb7227a4dc74e2bdc85ef8e500407e6251 (diff) |
mm-slab-move-debug-out.patch
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
-rw-r--r-- | mm/slab.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/mm/slab.c b/mm/slab.c index b76905ef21d2..1fd998310cc1 100644 --- a/mm/slab.c +++ b/mm/slab.c @@ -3851,10 +3851,10 @@ void kmem_cache_free(struct kmem_cache *cachep, void *objp) { unsigned long flags; - local_irq_save(flags); debug_check_no_locks_freed(objp, obj_size(cachep)); if (!(cachep->flags & SLAB_DEBUG_OBJECTS)) debug_check_no_obj_freed(objp, obj_size(cachep)); + local_irq_save(flags); __cache_free(cachep, objp, __builtin_return_address(0)); local_irq_restore(flags); @@ -3880,11 +3880,11 @@ void kfree(const void *objp) if (unlikely(ZERO_OR_NULL_PTR(objp))) return; - local_irq_save(flags); kfree_debugcheck(objp); c = virt_to_cache(objp); debug_check_no_locks_freed(objp, obj_size(c)); debug_check_no_obj_freed(objp, obj_size(c)); + local_irq_save(flags); __cache_free(c, (void *)objp, __builtin_return_address(0)); local_irq_restore(flags); } |