2010-11-08 19:09:23 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
|
|
|
|
* University Research and Technology
|
|
|
|
* Corporation. All rights reserved.
|
|
|
|
* Copyright (c) 2004-2006 The University of Tennessee and The University
|
|
|
|
* of Tennessee Research Foundation. All rights
|
|
|
|
* reserved.
|
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
|
|
* University of Stuttgart. All rights reserved.
|
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
|
|
|
* Copyright (c) 2010 Cisco Systems, Inc. All rights reserved.
|
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ORTE_THREAD_H
|
|
|
|
#define ORTE_THREAD_H
|
|
|
|
|
|
|
|
#include "orte_config.h"
|
|
|
|
|
|
|
|
#include "opal/class/opal_object.h"
|
|
|
|
#if OPAL_ENABLE_DEBUG
|
|
|
|
#include "opal/util/output.h"
|
|
|
|
#endif
|
2010-11-30 17:27:58 +00:00
|
|
|
#include "opal/util/fd.h"
|
|
|
|
#include "opal/mca/event/event.h"
|
2010-11-08 19:09:23 +00:00
|
|
|
|
|
|
|
#include "mutex.h"
|
|
|
|
#include "condition.h"
|
|
|
|
|
|
|
|
BEGIN_C_DECLS
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
opal_object_t super;
|
|
|
|
opal_mutex_t lock;
|
|
|
|
opal_condition_t cond;
|
|
|
|
volatile bool active;
|
|
|
|
volatile bool running;
|
|
|
|
volatile bool stop;
|
2010-12-01 04:26:43 +00:00
|
|
|
opal_event_base_t *evbase;
|
2010-11-30 17:27:58 +00:00
|
|
|
char *name;
|
2010-11-08 19:09:23 +00:00
|
|
|
} orte_thread_ctl_t;
|
2010-11-09 19:07:45 +00:00
|
|
|
ORTE_DECLSPEC OBJ_CLASS_DECLARATION(orte_thread_ctl_t);
|
2010-11-08 19:09:23 +00:00
|
|
|
|
|
|
|
#if OPAL_ENABLE_DEBUG
|
2010-11-30 17:27:58 +00:00
|
|
|
#define ORTE_ACQUIRE_THREAD(ctl) \
|
|
|
|
do { \
|
|
|
|
ORTE_THREAD_LOCK(&(ctl)->lock); \
|
|
|
|
if (opal_debug_threads) { \
|
|
|
|
opal_output(0, "Waiting for thread %s at %s:%d:%s", \
|
|
|
|
(NULL == (ctl)->name) ? "NULL" : (ctl)->name, \
|
|
|
|
__FILE__, __LINE__, \
|
|
|
|
((ctl)->active) ? "TRUE" : "FALSE"); \
|
|
|
|
} \
|
|
|
|
while ((ctl)->active) { \
|
|
|
|
ORTE_CONDITION_WAIT(&(ctl)->cond, &(ctl)->lock); \
|
|
|
|
} \
|
|
|
|
if (opal_debug_threads) { \
|
|
|
|
opal_output(0, "Thread %s acquired at %s:%d", \
|
|
|
|
(NULL == (ctl)->name) ? "NULL" : (ctl)->name, \
|
|
|
|
__FILE__, __LINE__); \
|
|
|
|
} \
|
|
|
|
(ctl)->active = true; \
|
2010-11-08 19:09:23 +00:00
|
|
|
} while(0);
|
|
|
|
#else
|
|
|
|
#define ORTE_ACQUIRE_THREAD(ctl) \
|
|
|
|
do { \
|
|
|
|
ORTE_THREAD_LOCK(&(ctl)->lock); \
|
|
|
|
while ((ctl)->active) { \
|
2010-11-30 17:27:58 +00:00
|
|
|
ORTE_CONDITION_WAIT(&(ctl)->cond, &(ctl)->lock); \
|
2010-11-08 19:09:23 +00:00
|
|
|
} \
|
|
|
|
(ctl)->active = true; \
|
|
|
|
} while(0);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#if OPAL_ENABLE_DEBUG
|
2010-11-30 17:27:58 +00:00
|
|
|
#define ORTE_RELEASE_THREAD(ctl) \
|
|
|
|
do { \
|
|
|
|
if (opal_debug_threads) { \
|
|
|
|
opal_output(0, "Releasing thread %s at %s:%d", \
|
|
|
|
(NULL == (ctl)->name) ? "NULL" : (ctl)->name, \
|
|
|
|
__FILE__, __LINE__); \
|
|
|
|
} \
|
|
|
|
(ctl)->active = false; \
|
|
|
|
ORTE_CONDITION_BROADCAST(&(ctl)->cond); \
|
2010-12-01 04:26:43 +00:00
|
|
|
OPAL_UPDATE_EVBASE((ctl)->evbase, NULL, OPAL_EVENT_NOOP); \
|
2010-11-30 17:27:58 +00:00
|
|
|
ORTE_THREAD_UNLOCK(&(ctl)->lock); \
|
2010-11-08 19:09:23 +00:00
|
|
|
} while(0);
|
|
|
|
#else
|
2010-11-30 17:27:58 +00:00
|
|
|
#define ORTE_RELEASE_THREAD(ctl) \
|
|
|
|
do { \
|
|
|
|
(ctl)->active = false; \
|
|
|
|
ORTE_CONDITION_BROADCAST(&(ctl)->cond); \
|
2010-12-01 04:26:43 +00:00
|
|
|
OPAL_UPDATE_EVBASE((ctl)->evbase, NULL, OPAL_EVENT_NOOP); \
|
2010-11-30 17:27:58 +00:00
|
|
|
ORTE_THREAD_UNLOCK(&(ctl)->lock); \
|
2010-11-08 19:09:23 +00:00
|
|
|
} while(0);
|
|
|
|
#endif
|
|
|
|
|
2010-11-30 17:27:58 +00:00
|
|
|
#if OPAL_ENABLE_DEBUG
|
|
|
|
#define ORTE_WAKEUP_THREAD(ctl) \
|
|
|
|
do { \
|
|
|
|
ORTE_THREAD_LOCK(&(ctl)->lock); \
|
|
|
|
if (opal_debug_threads) { \
|
|
|
|
opal_output(0, "Waking up thread %s at %s:%d", \
|
|
|
|
(NULL == (ctl)->name) ? "NULL" : (ctl)->name, \
|
|
|
|
__FILE__, __LINE__); \
|
|
|
|
} \
|
|
|
|
(ctl)->active = false; \
|
|
|
|
ORTE_CONDITION_BROADCAST(&(ctl)->cond); \
|
2010-12-01 04:26:43 +00:00
|
|
|
OPAL_UPDATE_EVBASE((ctl)->evbase, NULL, OPAL_EVENT_NOOP); \
|
2010-11-30 17:27:58 +00:00
|
|
|
ORTE_THREAD_UNLOCK(&(ctl)->lock); \
|
2010-11-08 19:09:23 +00:00
|
|
|
} while(0);
|
2010-11-30 17:27:58 +00:00
|
|
|
#else
|
|
|
|
#define ORTE_WAKEUP_THREAD(ctl) \
|
|
|
|
do { \
|
|
|
|
ORTE_THREAD_LOCK(&(ctl)->lock); \
|
|
|
|
(ctl)->active = false; \
|
|
|
|
ORTE_CONDITION_BROADCAST(&(ctl)->cond); \
|
2010-12-01 04:26:43 +00:00
|
|
|
OPAL_UPDATE_EVBASE((ctl)->evbase, NULL, OPAL_EVENT_NOOP); \
|
2010-11-30 17:27:58 +00:00
|
|
|
ORTE_THREAD_UNLOCK(&(ctl)->lock); \
|
|
|
|
} while(0);
|
|
|
|
#endif
|
2010-11-08 19:09:23 +00:00
|
|
|
|
|
|
|
END_C_DECLS
|
|
|
|
|
|
|
|
#endif /* ORTE_THREAD_H */
|