2015-08-21 10:36:49 -06:00
|
|
|
/* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */
|
2003-12-22 16:29:21 +00:00
|
|
|
/*
|
2005-11-05 19:57:48 +00:00
|
|
|
* Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
|
|
|
|
* University Research and Technology
|
|
|
|
* Corporation. All rights reserved.
|
2016-05-24 18:20:51 -05:00
|
|
|
* Copyright (c) 2004-2016 The University of Tennessee and The University
|
2005-11-05 19:57:48 +00:00
|
|
|
* of Tennessee Research Foundation. All rights
|
|
|
|
* reserved.
|
2015-06-23 20:59:57 -07:00
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
2004-11-28 20:09:25 +00:00
|
|
|
* University of Stuttgart. All rights reserved.
|
2005-03-24 12:43:37 +00:00
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
2009-01-11 02:30:00 +00:00
|
|
|
* Copyright (c) 2007 Cisco Systems, Inc. All rights reserved.
|
2016-02-23 09:58:32 -07:00
|
|
|
* Copyright (c) 2007-2016 Los Alamos National Security, LLC. All rights
|
2015-06-23 20:59:57 -07:00
|
|
|
* reserved.
|
2007-08-01 12:13:34 +00:00
|
|
|
* Copyright (c) 2007 Voltaire. All rights reserved.
|
2010-10-27 20:47:42 +00:00
|
|
|
* Copyright (c) 2010 Oracle and/or its affiliates. All rights reserved.
|
2007-08-01 12:13:34 +00:00
|
|
|
*
|
2004-11-22 01:38:40 +00:00
|
|
|
* $COPYRIGHT$
|
2015-06-23 20:59:57 -07:00
|
|
|
*
|
2004-11-22 01:38:40 +00:00
|
|
|
* Additional copyrights may follow
|
2015-06-23 20:59:57 -07:00
|
|
|
*
|
2004-01-07 18:39:35 +00:00
|
|
|
* $HEADER$
|
2003-12-22 16:29:21 +00:00
|
|
|
*/
|
2004-01-07 18:39:35 +00:00
|
|
|
|
2005-07-03 22:45:48 +00:00
|
|
|
#ifndef OPAL_MUTEX_H
|
|
|
|
#define OPAL_MUTEX_H 1
|
2003-12-22 16:29:21 +00:00
|
|
|
|
2006-02-12 01:33:29 +00:00
|
|
|
#include "opal_config.h"
|
2008-02-19 00:39:48 +00:00
|
|
|
|
2015-01-07 08:45:54 -07:00
|
|
|
#include "opal/threads/thread_usage.h"
|
2006-08-20 15:54:04 +00:00
|
|
|
|
2007-06-12 16:25:26 +00:00
|
|
|
BEGIN_C_DECLS
|
|
|
|
|
2004-08-18 23:24:27 +00:00
|
|
|
/**
|
|
|
|
* @file:
|
|
|
|
*
|
|
|
|
* Mutual exclusion functions.
|
|
|
|
*
|
|
|
|
* Functions for locking of critical sections.
|
|
|
|
*/
|
2007-06-12 16:25:26 +00:00
|
|
|
|
2004-08-18 23:24:27 +00:00
|
|
|
/**
|
|
|
|
* Opaque mutex object
|
|
|
|
*/
|
2005-07-03 22:45:48 +00:00
|
|
|
typedef struct opal_mutex_t opal_mutex_t;
|
2015-08-24 13:26:47 -06:00
|
|
|
typedef struct opal_mutex_t opal_recursive_mutex_t;
|
2004-08-18 23:24:27 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Try to acquire a mutex.
|
|
|
|
*
|
|
|
|
* @param mutex Address of the mutex.
|
|
|
|
* @return 0 if the mutex was acquired, 1 otherwise.
|
|
|
|
*/
|
2005-07-03 22:45:48 +00:00
|
|
|
static inline int opal_mutex_trylock(opal_mutex_t *mutex);
|
2004-08-18 23:24:27 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Acquire a mutex.
|
|
|
|
*
|
|
|
|
* @param mutex Address of the mutex.
|
|
|
|
*/
|
2005-07-03 22:45:48 +00:00
|
|
|
static inline void opal_mutex_lock(opal_mutex_t *mutex);
|
2004-08-18 23:24:27 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Release a mutex.
|
|
|
|
*
|
|
|
|
* @param mutex Address of the mutex.
|
|
|
|
*/
|
2005-07-03 22:45:48 +00:00
|
|
|
static inline void opal_mutex_unlock(opal_mutex_t *mutex);
|
2004-08-18 23:24:27 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Try to acquire a mutex using atomic operations.
|
|
|
|
*
|
|
|
|
* @param mutex Address of the mutex.
|
|
|
|
* @return 0 if the mutex was acquired, 1 otherwise.
|
|
|
|
*/
|
2005-07-03 22:45:48 +00:00
|
|
|
static inline int opal_mutex_atomic_trylock(opal_mutex_t *mutex);
|
2004-08-18 23:24:27 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Acquire a mutex using atomic operations.
|
|
|
|
*
|
|
|
|
* @param mutex Address of the mutex.
|
|
|
|
*/
|
2005-07-03 22:45:48 +00:00
|
|
|
static inline void opal_mutex_atomic_lock(opal_mutex_t *mutex);
|
2004-08-18 23:24:27 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Release a mutex using atomic operations.
|
|
|
|
*
|
|
|
|
* @param mutex Address of the mutex.
|
|
|
|
*/
|
2005-07-03 22:45:48 +00:00
|
|
|
static inline void opal_mutex_atomic_unlock(opal_mutex_t *mutex);
|
2004-08-18 23:24:27 +00:00
|
|
|
|
2007-06-12 16:25:26 +00:00
|
|
|
END_C_DECLS
|
|
|
|
|
|
|
|
#include "mutex_unix.h"
|
|
|
|
|
|
|
|
BEGIN_C_DECLS
|
2004-08-18 23:24:27 +00:00
|
|
|
|
2004-01-13 23:32:19 +00:00
|
|
|
/**
|
2005-07-03 22:45:48 +00:00
|
|
|
* Lock a mutex if opal_using_threads() says that multiple threads may
|
2004-01-13 23:32:19 +00:00
|
|
|
* be active in the process.
|
|
|
|
*
|
2005-07-03 22:45:48 +00:00
|
|
|
* @param mutex Pointer to a opal_mutex_t to lock.
|
2004-01-13 23:32:19 +00:00
|
|
|
*
|
|
|
|
* If there is a possibility that multiple threads are running in the
|
2005-07-03 22:45:48 +00:00
|
|
|
* process (as determined by opal_using_threads()), this function will
|
2004-01-13 23:32:19 +00:00
|
|
|
* block waiting to lock the mutex.
|
|
|
|
*
|
|
|
|
* If there is no possibility that multiple threads are running in the
|
|
|
|
* process, return immediately.
|
|
|
|
*/
|
2005-07-03 22:45:48 +00:00
|
|
|
#define OPAL_THREAD_LOCK(mutex) \
|
2004-08-18 23:24:27 +00:00
|
|
|
do { \
|
2016-02-23 09:58:32 -07:00
|
|
|
if (OPAL_UNLIKELY(opal_using_threads())) { \
|
2005-07-03 22:45:48 +00:00
|
|
|
opal_mutex_lock(mutex); \
|
2004-08-18 23:24:27 +00:00
|
|
|
} \
|
|
|
|
} while (0)
|
2004-01-10 22:22:50 +00:00
|
|
|
|
2007-06-12 16:25:26 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Try to lock a mutex if opal_using_threads() says that multiple
|
|
|
|
* threads may be active in the process.
|
|
|
|
*
|
|
|
|
* @param mutex Pointer to a opal_mutex_t to trylock
|
|
|
|
*
|
|
|
|
* If there is a possibility that multiple threads are running in the
|
|
|
|
* process (as determined by opal_using_threads()), this function will
|
|
|
|
* trylock the mutex.
|
|
|
|
*
|
|
|
|
* If there is no possibility that multiple threads are running in the
|
|
|
|
* process, return immediately without modifying the mutex.
|
|
|
|
*
|
|
|
|
* Returns 0 if mutex was locked, non-zero otherwise.
|
|
|
|
*/
|
2013-12-13 19:40:12 +00:00
|
|
|
#define OPAL_THREAD_TRYLOCK(mutex) \
|
2016-02-23 09:58:32 -07:00
|
|
|
(OPAL_UNLIKELY(opal_using_threads()) ? opal_mutex_trylock(mutex) : 0)
|
2005-04-12 19:51:29 +00:00
|
|
|
|
|
|
|
/**
|
2005-07-03 22:45:48 +00:00
|
|
|
* Unlock a mutex if opal_using_threads() says that multiple threads
|
2004-01-13 23:32:19 +00:00
|
|
|
* may be active in the process.
|
|
|
|
*
|
2005-07-03 22:45:48 +00:00
|
|
|
* @param mutex Pointer to a opal_mutex_t to unlock.
|
2004-01-13 23:32:19 +00:00
|
|
|
*
|
|
|
|
* If there is a possibility that multiple threads are running in the
|
2005-07-03 22:45:48 +00:00
|
|
|
* process (as determined by opal_using_threads()), this function will
|
2004-01-13 23:32:19 +00:00
|
|
|
* unlock the mutex.
|
|
|
|
*
|
|
|
|
* If there is no possibility that multiple threads are running in the
|
|
|
|
* process, return immediately without modifying the mutex.
|
2004-01-10 22:22:50 +00:00
|
|
|
*/
|
2005-07-03 22:45:48 +00:00
|
|
|
#define OPAL_THREAD_UNLOCK(mutex) \
|
2004-08-18 23:24:27 +00:00
|
|
|
do { \
|
2016-02-23 09:58:32 -07:00
|
|
|
if (OPAL_UNLIKELY(opal_using_threads())) { \
|
2005-07-03 22:45:48 +00:00
|
|
|
opal_mutex_unlock(mutex); \
|
2004-08-18 23:24:27 +00:00
|
|
|
} \
|
|
|
|
} while (0)
|
2005-04-19 20:50:44 +00:00
|
|
|
|
2004-08-18 23:24:27 +00:00
|
|
|
|
|
|
|
/**
|
2005-07-03 22:45:48 +00:00
|
|
|
* Lock a mutex if opal_using_threads() says that multiple threads may
|
2004-08-18 23:24:27 +00:00
|
|
|
* be active in the process for the duration of the specified action.
|
|
|
|
*
|
2005-07-03 22:45:48 +00:00
|
|
|
* @param mutex Pointer to a opal_mutex_t to lock.
|
2004-08-18 23:24:27 +00:00
|
|
|
* @param action A scope over which the lock is held.
|
|
|
|
*
|
|
|
|
* If there is a possibility that multiple threads are running in the
|
2005-07-03 22:45:48 +00:00
|
|
|
* process (as determined by opal_using_threads()), this function will
|
2004-08-18 23:24:27 +00:00
|
|
|
* acquire the lock before invoking the specified action and release
|
|
|
|
* it on return.
|
|
|
|
*
|
|
|
|
* If there is no possibility that multiple threads are running in the
|
|
|
|
* process, invoke the action without acquiring the lock.
|
|
|
|
*/
|
2005-07-03 22:45:48 +00:00
|
|
|
#define OPAL_THREAD_SCOPED_LOCK(mutex, action) \
|
2004-08-18 23:24:27 +00:00
|
|
|
do { \
|
2016-02-23 09:58:32 -07:00
|
|
|
if(OPAL_UNLIKELY(opal_using_threads())) { \
|
2005-07-03 22:45:48 +00:00
|
|
|
opal_mutex_lock(mutex); \
|
2015-08-21 10:36:49 -06:00
|
|
|
action; \
|
2005-07-03 22:45:48 +00:00
|
|
|
opal_mutex_unlock(mutex); \
|
2004-08-18 23:24:27 +00:00
|
|
|
} else { \
|
2015-08-21 10:36:49 -06:00
|
|
|
action; \
|
2004-08-18 23:24:27 +00:00
|
|
|
} \
|
|
|
|
} while (0)
|
|
|
|
|
2007-06-12 16:25:26 +00:00
|
|
|
END_C_DECLS
|
2003-12-22 16:29:21 +00:00
|
|
|
|
2005-07-03 22:45:48 +00:00
|
|
|
#endif /* OPAL_MUTEX_H */
|