mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-09 22:50:41 +00:00
1fb00c6cbd
It seems ppc64 wants to lock mutexes in early bootup code, with interrupts disabled, and they expect interrupts to stay disabled, else they crash. Work around this bug by making mutex debugging variants save/restore irq flags. Signed-off-by: Ingo Molnar <mingo@elte.hu> Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org> Cc: Paul Mackerras <paulus@samba.org> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
38 lines
1.3 KiB
C
38 lines
1.3 KiB
C
/*
|
|
* Mutexes: blocking mutual exclusion locks
|
|
*
|
|
* started by Ingo Molnar:
|
|
*
|
|
* Copyright (C) 2004, 2005, 2006 Red Hat, Inc., Ingo Molnar <mingo@redhat.com>
|
|
*
|
|
* This file contains mutex debugging related internal prototypes, for the
|
|
* !CONFIG_DEBUG_MUTEXES case. Most of them are NOPs:
|
|
*/
|
|
|
|
#define spin_lock_mutex(lock, flags) \
|
|
do { spin_lock(lock); (void)(flags); } while (0)
|
|
#define spin_unlock_mutex(lock, flags) \
|
|
do { spin_unlock(lock); (void)(flags); } while (0)
|
|
#define mutex_remove_waiter(lock, waiter, ti) \
|
|
__list_del((waiter)->list.prev, (waiter)->list.next)
|
|
|
|
#define DEBUG_WARN_ON(c) do { } while (0)
|
|
#define debug_mutex_set_owner(lock, new_owner) do { } while (0)
|
|
#define debug_mutex_clear_owner(lock) do { } while (0)
|
|
#define debug_mutex_init_waiter(waiter) do { } while (0)
|
|
#define debug_mutex_wake_waiter(lock, waiter) do { } while (0)
|
|
#define debug_mutex_free_waiter(waiter) do { } while (0)
|
|
#define debug_mutex_add_waiter(lock, waiter, ti, ip) do { } while (0)
|
|
#define debug_mutex_unlock(lock) do { } while (0)
|
|
#define debug_mutex_init(lock, name) do { } while (0)
|
|
|
|
/*
|
|
* Return-address parameters/declarations. They are very useful for
|
|
* debugging, but add overhead in the !DEBUG case - so we go the
|
|
* trouble of using this not too elegant but zero-cost solution:
|
|
*/
|
|
#define __IP_DECL__
|
|
#define __IP__
|
|
#define __RET_IP__
|
|
|