mirror of
https://github.com/adulau/aha.git
synced 2024-12-27 11:16:11 +00:00
[PATCH] pi-futex: introduce debug_check_no_locks_freed()
Add debug_check_no_locks_freed(), as a central inline to add bad-lock-free-debugging functionality to. Signed-off-by: Ingo Molnar <mingo@elte.hu> Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Signed-off-by: Arjan van de Ven <arjan@linux.intel.com> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
parent
6abdce7680
commit
f9b8404cf8
4 changed files with 13 additions and 7 deletions
|
@ -229,8 +229,8 @@ void kernel_map_pages(struct page *page, int numpages, int enable)
|
|||
if (PageHighMem(page))
|
||||
return;
|
||||
if (!enable)
|
||||
mutex_debug_check_no_locks_freed(page_address(page),
|
||||
numpages * PAGE_SIZE);
|
||||
debug_check_no_locks_freed(page_address(page),
|
||||
numpages * PAGE_SIZE);
|
||||
|
||||
/* the return value is ignored - the calls cannot fail,
|
||||
* large pages are disabled at boot time.
|
||||
|
|
|
@ -1030,13 +1030,19 @@ static inline void vm_stat_account(struct mm_struct *mm,
|
|||
}
|
||||
#endif /* CONFIG_PROC_FS */
|
||||
|
||||
static inline void
|
||||
debug_check_no_locks_freed(const void *from, unsigned long len)
|
||||
{
|
||||
mutex_debug_check_no_locks_freed(from, len);
|
||||
}
|
||||
|
||||
#ifndef CONFIG_DEBUG_PAGEALLOC
|
||||
static inline void
|
||||
kernel_map_pages(struct page *page, int numpages, int enable)
|
||||
{
|
||||
if (!PageHighMem(page) && !enable)
|
||||
mutex_debug_check_no_locks_freed(page_address(page),
|
||||
numpages * PAGE_SIZE);
|
||||
debug_check_no_locks_freed(page_address(page),
|
||||
numpages * PAGE_SIZE);
|
||||
}
|
||||
#endif
|
||||
|
||||
|
|
|
@ -446,8 +446,8 @@ static void __free_pages_ok(struct page *page, unsigned int order)
|
|||
|
||||
arch_free_page(page, order);
|
||||
if (!PageHighMem(page))
|
||||
mutex_debug_check_no_locks_freed(page_address(page),
|
||||
PAGE_SIZE<<order);
|
||||
debug_check_no_locks_freed(page_address(page),
|
||||
PAGE_SIZE<<order);
|
||||
|
||||
for (i = 0 ; i < (1 << order) ; ++i)
|
||||
reserved += free_pages_check(page + i);
|
||||
|
|
|
@ -3397,7 +3397,7 @@ void kfree(const void *objp)
|
|||
local_irq_save(flags);
|
||||
kfree_debugcheck(objp);
|
||||
c = virt_to_cache(objp);
|
||||
mutex_debug_check_no_locks_freed(objp, obj_size(c));
|
||||
debug_check_no_locks_freed(objp, obj_size(c));
|
||||
__cache_free(c, (void *)objp);
|
||||
local_irq_restore(flags);
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue