diff --git a/include/sys/mutex.h b/include/sys/mutex.h index 31497f6a1..43467223c 100644 --- a/include/sys/mutex.h +++ b/include/sys/mutex.h @@ -1,4 +1,4 @@ -/*****************************************************************************\ +/* * Copyright (C) 2007-2010 Lawrence Livermore National Security, LLC. * Copyright (C) 2007 The Regents of the University of California. * Produced at Lawrence Livermore National Laboratory (cf, DISCLAIMER). @@ -20,72 +20,68 @@ * * You should have received a copy of the GNU General Public License along * with the SPL. If not, see . -\*****************************************************************************/ + */ #ifndef _SPL_MUTEX_H -#define _SPL_MUTEX_H +#define _SPL_MUTEX_H #include #include #include typedef enum { - MUTEX_DEFAULT = 0, - MUTEX_SPIN = 1, - MUTEX_ADAPTIVE = 2 + MUTEX_DEFAULT = 0, + MUTEX_SPIN = 1, + MUTEX_ADAPTIVE = 2 } kmutex_type_t; #if defined(HAVE_MUTEX_OWNER) && defined(CONFIG_SMP) && \ - !defined(CONFIG_DEBUG_MUTEXES) + !defined(CONFIG_DEBUG_MUTEXES) -/* - * We define a 1-field struct rather than a straight typedef to enforce type - * safety. - */ typedef struct { - struct mutex m; - spinlock_t m_lock; /* used for serializing mutex_exit */ + struct mutex m; + spinlock_t m_lock; /* used for serializing mutex_exit */ } kmutex_t; static inline kthread_t * mutex_owner(kmutex_t *mp) { #if defined(HAVE_MUTEX_OWNER_TASK_STRUCT) - return ACCESS_ONCE(mp->m.owner); + return (ACCESS_ONCE(mp->m.owner)); #else struct thread_info *owner = ACCESS_ONCE(mp->m.owner); if (owner) - return owner->task; + return (owner->task); - return NULL; + return (NULL); #endif } -#define mutex_owned(mp) (mutex_owner(mp) == current) -#define MUTEX_HELD(mp) mutex_owned(mp) -#define MUTEX_NOT_HELD(mp) (!MUTEX_HELD(mp)) +#define mutex_owned(mp) (mutex_owner(mp) == current) +#define MUTEX_HELD(mp) mutex_owned(mp) +#define MUTEX_NOT_HELD(mp) (!MUTEX_HELD(mp)) #undef mutex_init -#define mutex_init(mp, name, type, ibc) \ -({ \ - static struct lock_class_key __key; \ - ASSERT(type == MUTEX_DEFAULT); \ - \ - __mutex_init(&(mp)->m, #mp, &__key); \ - spin_lock_init(&(mp)->m_lock); \ -}) +#define mutex_init(mp, name, type, ibc) \ +{ \ + static struct lock_class_key __key; \ + ASSERT(type == MUTEX_DEFAULT); \ + \ + __mutex_init(&(mp)->m, #mp, &__key); \ + spin_lock_init(&(mp)->m_lock); \ +} #undef mutex_destroy -#define mutex_destroy(mp) \ -({ \ - VERIFY3P(mutex_owner(mp), ==, NULL); \ -}) +#define mutex_destroy(mp) \ +{ \ + VERIFY3P(mutex_owner(mp), ==, NULL); \ +} -#define mutex_tryenter(mp) mutex_trylock(&(mp)->m) -#define mutex_enter(mp) \ -({ \ - ASSERT3P(mutex_owner(mp), !=, current); \ - mutex_lock(&(mp)->m); \ -}) +#define mutex_tryenter(mp) mutex_trylock(&(mp)->m) +#define mutex_enter(mp) \ +{ \ + ASSERT3P(mutex_owner(mp), !=, current); \ + mutex_lock(&(mp)->m); \ +} /* * The reason for the spinlock: * @@ -105,39 +101,39 @@ mutex_owner(kmutex_t *mp) * * See http://lwn.net/Articles/575477/ for the information about the race. */ -#define mutex_exit(mp) \ -({ \ - spin_lock(&(mp)->m_lock); \ - mutex_unlock(&(mp)->m); \ - spin_unlock(&(mp)->m_lock); \ -}) +#define mutex_exit(mp) \ +{ \ + spin_lock(&(mp)->m_lock); \ + mutex_unlock(&(mp)->m); \ + spin_unlock(&(mp)->m_lock); \ +} #else /* HAVE_MUTEX_OWNER */ typedef struct { - struct mutex m_mutex; - spinlock_t m_lock; - kthread_t *m_owner; + struct mutex m_mutex; + spinlock_t m_lock; /* used for serializing mutex_exit */ + kthread_t *m_owner; } kmutex_t; -#define MUTEX(mp) (&((mp)->m_mutex)) +#define MUTEX(mp) (&((mp)->m_mutex)) static inline void spl_mutex_set_owner(kmutex_t *mp) { - mp->m_owner = current; + mp->m_owner = current; } static inline void spl_mutex_clear_owner(kmutex_t *mp) { - mp->m_owner = NULL; + mp->m_owner = NULL; } -#define mutex_owner(mp) (ACCESS_ONCE((mp)->m_owner)) -#define mutex_owned(mp) (mutex_owner(mp) == current) -#define MUTEX_HELD(mp) mutex_owned(mp) -#define MUTEX_NOT_HELD(mp) (!MUTEX_HELD(mp)) +#define mutex_owner(mp) (ACCESS_ONCE((mp)->m_owner)) +#define mutex_owned(mp) (mutex_owner(mp) == current) +#define MUTEX_HELD(mp) mutex_owned(mp) +#define MUTEX_NOT_HELD(mp) (!MUTEX_HELD(mp)) /* * The following functions must be a #define and not static inline. @@ -146,46 +142,46 @@ spl_mutex_clear_owner(kmutex_t *mp) * for the built in kernel lock analysis tools */ #undef mutex_init -#define mutex_init(mp, name, type, ibc) \ -({ \ - static struct lock_class_key __key; \ - ASSERT(type == MUTEX_DEFAULT); \ - \ - __mutex_init(MUTEX(mp), #mp, &__key); \ - spin_lock_init(&(mp)->m_lock); \ - spl_mutex_clear_owner(mp); \ -}) +#define mutex_init(mp, name, type, ibc) \ +{ \ + static struct lock_class_key __key; \ + ASSERT(type == MUTEX_DEFAULT); \ + \ + __mutex_init(MUTEX(mp), #mp, &__key); \ + spin_lock_init(&(mp)->m_lock); \ + spl_mutex_clear_owner(mp); \ +} #undef mutex_destroy -#define mutex_destroy(mp) \ -({ \ - VERIFY3P(mutex_owner(mp), ==, NULL); \ +#define mutex_destroy(mp) \ +{ \ + VERIFY3P(mutex_owner(mp), ==, NULL); \ +} + +#define mutex_tryenter(mp) \ +({ \ + int _rc_; \ + \ + if ((_rc_ = mutex_trylock(MUTEX(mp))) == 1) \ + spl_mutex_set_owner(mp); \ + \ + _rc_; \ }) -#define mutex_tryenter(mp) \ -({ \ - int _rc_; \ - \ - if ((_rc_ = mutex_trylock(MUTEX(mp))) == 1) \ - spl_mutex_set_owner(mp); \ - \ - _rc_; \ -}) +#define mutex_enter(mp) \ +{ \ + ASSERT3P(mutex_owner(mp), !=, current); \ + mutex_lock(MUTEX(mp)); \ + spl_mutex_set_owner(mp); \ +} -#define mutex_enter(mp) \ -({ \ - ASSERT3P(mutex_owner(mp), !=, current); \ - mutex_lock(MUTEX(mp)); \ - spl_mutex_set_owner(mp); \ -}) - -#define mutex_exit(mp) \ -({ \ - spin_lock(&(mp)->m_lock); \ - spl_mutex_clear_owner(mp); \ - mutex_unlock(MUTEX(mp)); \ - spin_unlock(&(mp)->m_lock); \ -}) +#define mutex_exit(mp) \ +{ \ + spin_lock(&(mp)->m_lock); \ + spl_mutex_clear_owner(mp); \ + mutex_unlock(MUTEX(mp)); \ + spin_unlock(&(mp)->m_lock); \ +} #endif /* HAVE_MUTEX_OWNER */