Commit 78515930 authored by Sebastian Andrzej Siewior's avatar Sebastian Andrzej Siewior Committed by Ingo Molnar
Browse files

locking/rtmutex: Convert macros to inlines

parent f07ec522
Loading
Loading
Loading
Loading
+27 −4
Original line number Diff line number Diff line
@@ -141,8 +141,19 @@ static __always_inline void fixup_rt_mutex_waiters(struct rt_mutex *lock)
 * set up.
 */
#ifndef CONFIG_DEBUG_RT_MUTEXES
# define rt_mutex_cmpxchg_acquire(l,c,n) (cmpxchg_acquire(&l->owner, c, n) == c)
# define rt_mutex_cmpxchg_release(l,c,n) (cmpxchg_release(&l->owner, c, n) == c)
static __always_inline bool rt_mutex_cmpxchg_acquire(struct rt_mutex *lock,
						     struct task_struct *old,
						     struct task_struct *new)
{
	return cmpxchg_acquire(&lock->owner, old, new) == old;
}

static __always_inline bool rt_mutex_cmpxchg_release(struct rt_mutex *lock,
						     struct task_struct *old,
						     struct task_struct *new)
{
	return cmpxchg_release(&lock->owner, old, new) == old;
}

/*
 * Callers must hold the ->wait_lock -- which is the whole purpose as we force
@@ -201,8 +212,20 @@ static __always_inline bool unlock_rt_mutex_safe(struct rt_mutex *lock,
}

#else
# define rt_mutex_cmpxchg_acquire(l,c,n)	(0)
# define rt_mutex_cmpxchg_release(l,c,n)	(0)
static __always_inline bool rt_mutex_cmpxchg_acquire(struct rt_mutex *lock,
						     struct task_struct *old,
						     struct task_struct *new)
{
	return false;

}

static __always_inline bool rt_mutex_cmpxchg_release(struct rt_mutex *lock,
						     struct task_struct *old,
						     struct task_struct *new)
{
	return false;
}

static __always_inline void mark_rt_mutex_waiters(struct rt_mutex *lock)
{