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.
|
2006-08-23 00:29:35 +00:00
|
|
|
* Copyright (c) 2004-2006 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.
|
2010-08-05 16:25:32 +00:00
|
|
|
* Copyright (c) 2010 Cisco Systems, Inc. All rights reserved.
|
2010-11-19 15:47:48 +00:00
|
|
|
* Copyright (c) 2010 Oracle and/or its affiliates. All rights reserved.
|
2016-10-26 15:38:45 +09:00
|
|
|
* Copyright (c) 2015-2017 Research Organization for Information Science
|
2014-10-21 19:49:58 +09:00
|
|
|
* and Technology (RIST). All rights reserved.
|
2017-06-05 15:22:28 -07:00
|
|
|
* Copyright (c) 2017 Intel, Inc. All rights reserved.
|
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 08:02:26 +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_THREAD_H
|
|
|
|
#define OPAL_THREAD_H 1
|
2003-12-22 16:29:21 +00:00
|
|
|
|
2009-03-04 15:35:54 +00:00
|
|
|
#include "opal_config.h"
|
|
|
|
|
2004-03-03 16:10:26 +00:00
|
|
|
#include <pthread.h>
|
2013-07-08 17:40:38 +00:00
|
|
|
#include <signal.h>
|
2004-08-18 23:24:27 +00:00
|
|
|
|
2005-07-03 16:06:07 +00:00
|
|
|
#include "opal/class/opal_object.h"
|
2010-08-05 16:25:32 +00:00
|
|
|
#if OPAL_ENABLE_DEBUG
|
|
|
|
#include "opal/util/output.h"
|
|
|
|
#endif
|
|
|
|
|
2010-03-22 15:45:03 +00:00
|
|
|
#include "mutex.h"
|
|
|
|
#include "condition.h"
|
2006-08-23 00:29:35 +00:00
|
|
|
|
2009-08-20 11:42:18 +00:00
|
|
|
BEGIN_C_DECLS
|
2003-12-22 16:29:21 +00:00
|
|
|
|
2005-07-03 22:45:48 +00:00
|
|
|
typedef void *(*opal_thread_fn_t) (opal_object_t *);
|
2004-03-03 16:10:26 +00:00
|
|
|
|
2010-01-23 03:57:24 +00:00
|
|
|
#define OPAL_THREAD_CANCELLED ((void*)1);
|
2004-03-03 16:10:26 +00:00
|
|
|
|
2005-07-03 22:45:48 +00:00
|
|
|
struct opal_thread_t {
|
2005-07-03 16:06:07 +00:00
|
|
|
opal_object_t super;
|
2005-07-03 22:45:48 +00:00
|
|
|
opal_thread_fn_t t_run;
|
2004-10-27 13:50:27 +00:00
|
|
|
void* t_arg;
|
2004-03-03 16:10:26 +00:00
|
|
|
pthread_t t_handle;
|
|
|
|
};
|
2004-08-18 23:24:27 +00:00
|
|
|
|
2005-07-03 22:45:48 +00:00
|
|
|
typedef struct opal_thread_t opal_thread_t;
|
2004-03-03 16:10:26 +00:00
|
|
|
|
2010-08-05 16:25:32 +00:00
|
|
|
#if OPAL_ENABLE_DEBUG
|
|
|
|
OPAL_DECLSPEC extern bool opal_debug_threads;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2006-08-20 15:54:04 +00:00
|
|
|
OPAL_DECLSPEC OBJ_CLASS_DECLARATION(opal_thread_t);
|
2003-12-22 16:29:21 +00:00
|
|
|
|
2010-08-05 16:25:32 +00:00
|
|
|
#if OPAL_ENABLE_DEBUG
|
|
|
|
#define OPAL_ACQUIRE_THREAD(lck, cnd, act) \
|
|
|
|
do { \
|
|
|
|
OPAL_THREAD_LOCK((lck)); \
|
|
|
|
if (opal_debug_threads) { \
|
|
|
|
opal_output(0, "Waiting for thread %s:%d", \
|
|
|
|
__FILE__, __LINE__); \
|
|
|
|
} \
|
|
|
|
while (*(act)) { \
|
|
|
|
opal_condition_wait((cnd), (lck)); \
|
|
|
|
} \
|
|
|
|
if (opal_debug_threads) { \
|
|
|
|
opal_output(0, "Thread obtained %s:%d", \
|
|
|
|
__FILE__, __LINE__); \
|
|
|
|
} \
|
|
|
|
*(act) = true; \
|
|
|
|
} while(0);
|
|
|
|
#else
|
|
|
|
#define OPAL_ACQUIRE_THREAD(lck, cnd, act) \
|
|
|
|
do { \
|
|
|
|
OPAL_THREAD_LOCK((lck)); \
|
|
|
|
while (*(act)) { \
|
|
|
|
opal_condition_wait((cnd), (lck)); \
|
|
|
|
} \
|
|
|
|
*(act) = true; \
|
2010-03-22 15:45:03 +00:00
|
|
|
} while(0);
|
2010-08-05 16:25:32 +00:00
|
|
|
#endif
|
|
|
|
|
2010-03-22 15:45:03 +00:00
|
|
|
|
2010-08-05 16:25:32 +00:00
|
|
|
#if OPAL_ENABLE_DEBUG
|
|
|
|
#define OPAL_RELEASE_THREAD(lck, cnd, act) \
|
|
|
|
do { \
|
|
|
|
if (opal_debug_threads) { \
|
|
|
|
opal_output(0, "Releasing thread %s:%d", \
|
|
|
|
__FILE__, __LINE__); \
|
|
|
|
} \
|
|
|
|
*(act) = false; \
|
|
|
|
opal_condition_broadcast((cnd)); \
|
|
|
|
OPAL_THREAD_UNLOCK((lck)); \
|
|
|
|
} while(0);
|
|
|
|
#else
|
|
|
|
#define OPAL_RELEASE_THREAD(lck, cnd, act) \
|
|
|
|
do { \
|
|
|
|
*(act) = false; \
|
|
|
|
opal_condition_broadcast((cnd)); \
|
|
|
|
OPAL_THREAD_UNLOCK((lck)); \
|
2010-03-22 15:45:03 +00:00
|
|
|
} while(0);
|
2010-08-05 16:25:32 +00:00
|
|
|
#endif
|
|
|
|
|
2010-03-22 15:45:03 +00:00
|
|
|
|
2010-04-06 22:40:45 +00:00
|
|
|
#define OPAL_WAKEUP_THREAD(cnd, act) \
|
|
|
|
do { \
|
|
|
|
*(act) = false; \
|
|
|
|
opal_condition_broadcast((cnd)); \
|
|
|
|
} while(0);
|
|
|
|
|
2017-06-05 15:22:28 -07:00
|
|
|
/* provide a macro for forward-proofing the shifting
|
|
|
|
* of objects between libevent threads - at some point, we
|
|
|
|
* may revamp that threading model */
|
|
|
|
|
|
|
|
/* post an object to another thread - for now, we
|
|
|
|
* only have a memory barrier */
|
|
|
|
#define OPAL_POST_OBJECT(o) opal_atomic_wmb()
|
|
|
|
|
|
|
|
/* acquire an object from another thread - for now,
|
|
|
|
* we only have a memory barrier */
|
|
|
|
#define OPAL_ACQUIRE_OBJECT(o) opal_atomic_rmb()
|
|
|
|
|
|
|
|
|
2010-03-22 15:45:03 +00:00
|
|
|
|
2006-08-23 00:29:35 +00:00
|
|
|
OPAL_DECLSPEC int opal_thread_start(opal_thread_t *);
|
|
|
|
OPAL_DECLSPEC int opal_thread_join(opal_thread_t *, void **thread_return);
|
|
|
|
OPAL_DECLSPEC bool opal_thread_self_compare(opal_thread_t*);
|
|
|
|
OPAL_DECLSPEC opal_thread_t *opal_thread_get_self(void);
|
2010-11-08 19:06:10 +00:00
|
|
|
OPAL_DECLSPEC void opal_thread_kill(opal_thread_t *, int sig);
|
2016-10-26 15:38:45 +09:00
|
|
|
OPAL_DECLSPEC void opal_thread_set_main(void);
|
2006-08-20 15:54:04 +00:00
|
|
|
|
2009-08-20 11:42:18 +00:00
|
|
|
END_C_DECLS
|
2003-12-22 16:29:21 +00:00
|
|
|
|
2005-07-03 22:45:48 +00:00
|
|
|
#endif /* OPAL_THREAD_H */
|