2014-12-05 02:18:16 +03:00
|
|
|
/* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */
|
|
|
|
/*
|
2015-01-06 02:03:15 +03:00
|
|
|
* Copyright (c) 2011-2015 Los Alamos National Security, LLC. All rights
|
2014-12-05 02:18:16 +03:00
|
|
|
* reserved.
|
|
|
|
* Copyright (c) 2011 UT-Battelle, LLC. All rights reserved.
|
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "opal_config.h"
|
|
|
|
|
|
|
|
#include "btl_ugni.h"
|
|
|
|
#include "btl_ugni_frag.h"
|
|
|
|
#include "btl_ugni_smsg.h"
|
|
|
|
|
|
|
|
#include "opal/include/opal/align.h"
|
|
|
|
|
|
|
|
|
|
|
|
static pthread_t mca_btl_ugni_progress_thread_id;
|
|
|
|
static pthread_mutex_t progress_mutex = PTHREAD_MUTEX_INITIALIZER;
|
|
|
|
static pthread_cond_t progress_cond = PTHREAD_COND_INITIALIZER;
|
|
|
|
|
|
|
|
static volatile int stop_progress_thread = 0;
|
|
|
|
static volatile int progress_thread_done = 0;
|
|
|
|
|
|
|
|
static int thread_wakeups = 0;
|
|
|
|
|
|
|
|
static void *mca_btl_ugni_prog_thread_fn(void * data)
|
|
|
|
{
|
2014-12-24 21:40:27 +03:00
|
|
|
int rc,ret = OPAL_SUCCESS;
|
2014-12-05 02:18:16 +03:00
|
|
|
uint32_t which;
|
|
|
|
gni_return_t status;
|
|
|
|
gni_cq_handle_t cq_vec[2];
|
|
|
|
|
|
|
|
struct mca_btl_ugni_module_t *btl = (mca_btl_ugni_module_t *)data;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* need to block signals
|
|
|
|
*/
|
|
|
|
|
|
|
|
cq_vec[0] = btl->smsg_remote_irq_cq;
|
|
|
|
cq_vec[1] = btl->rdma_local_irq_cq;
|
|
|
|
|
|
|
|
|
|
|
|
while (stop_progress_thread == 0) {
|
|
|
|
|
|
|
|
/*
|
|
|
|
* this ugni call doesn't need a lock
|
|
|
|
*/
|
|
|
|
|
|
|
|
status = GNI_CqVectorMonitor(cq_vec,
|
|
|
|
2,
|
|
|
|
-1,
|
|
|
|
&which);
|
|
|
|
|
|
|
|
if (status == GNI_RC_NOT_DONE) continue;
|
|
|
|
|
|
|
|
if ((status == GNI_RC_SUCCESS) && (stop_progress_thread == 0)) {
|
|
|
|
thread_wakeups++;
|
|
|
|
opal_progress();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Send a signal to the main thread saying we are done */
|
|
|
|
rc = pthread_mutex_lock(&progress_mutex);
|
2014-12-24 21:40:27 +03:00
|
|
|
if (0 != rc) {
|
|
|
|
BTL_ERROR(("btl/ugni pthread_mutex_lock returned %s ",strerror(rc)));
|
|
|
|
ret = OPAL_ERROR;
|
|
|
|
goto fn_exit;
|
2014-12-05 02:18:16 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
progress_thread_done = 1;
|
|
|
|
|
|
|
|
rc = pthread_mutex_unlock(&progress_mutex);
|
2014-12-24 21:40:27 +03:00
|
|
|
if (0 != rc) {
|
|
|
|
BTL_ERROR(("btl/ugni pthread_mutex_unlock returned %s ",strerror(rc)));
|
|
|
|
ret = OPAL_ERROR;
|
|
|
|
goto fn_exit;
|
2014-12-05 02:18:16 +03:00
|
|
|
}
|
2014-12-24 21:40:27 +03:00
|
|
|
|
2014-12-05 02:18:16 +03:00
|
|
|
rc = pthread_cond_signal(&progress_cond);
|
2014-12-24 21:40:27 +03:00
|
|
|
if (0 != rc) {
|
|
|
|
BTL_ERROR(("btl/ugni pthread_cond_signal returned %s ",strerror(rc)));
|
|
|
|
ret = OPAL_ERROR;
|
|
|
|
}
|
2014-12-05 02:18:16 +03:00
|
|
|
|
2014-12-24 21:40:27 +03:00
|
|
|
fn_exit:
|
2015-01-06 02:03:15 +03:00
|
|
|
return (void *) (intptr_t) ret;
|
2014-12-05 02:18:16 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
int mca_btl_ugni_spawn_progress_thread(struct mca_btl_base_module_t *btl)
|
|
|
|
{
|
2014-12-24 21:40:27 +03:00
|
|
|
int rc, ret=OPAL_SUCCESS;
|
2014-12-05 02:18:16 +03:00
|
|
|
pthread_attr_t attr;
|
|
|
|
|
|
|
|
pthread_attr_init(&attr);
|
2014-12-24 21:40:27 +03:00
|
|
|
rc = pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED);
|
|
|
|
if (0 != rc) {
|
|
|
|
BTL_ERROR(("btl/ugni pthread_attr_setdetachstate returned %s ",strerror(rc)));
|
|
|
|
ret = OPAL_ERROR;
|
|
|
|
goto fn_exit;
|
|
|
|
}
|
2014-12-05 02:18:16 +03:00
|
|
|
|
|
|
|
rc = pthread_create(&mca_btl_ugni_progress_thread_id,
|
|
|
|
&attr, mca_btl_ugni_prog_thread_fn, (void *)btl);
|
2014-12-24 21:40:27 +03:00
|
|
|
if (0 != rc) {
|
|
|
|
BTL_ERROR(("btl/ugni pthread_create returned %s ",strerror(rc)));
|
|
|
|
ret = OPAL_ERROR;
|
|
|
|
goto fn_exit;
|
2014-12-05 02:18:16 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
rc = pthread_attr_destroy(&attr);
|
2014-12-24 21:40:27 +03:00
|
|
|
if (0 != rc) {
|
|
|
|
BTL_ERROR(("btl/ugni pthread_attr_destory returned %s ",strerror(rc)));
|
|
|
|
ret = OPAL_ERROR;
|
2014-12-05 02:18:16 +03:00
|
|
|
}
|
|
|
|
|
2014-12-24 21:40:27 +03:00
|
|
|
fn_exit:
|
|
|
|
return ret;
|
2014-12-05 02:18:16 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
int mca_btl_ugni_kill_progress_thread(void)
|
|
|
|
{
|
2014-12-24 21:40:27 +03:00
|
|
|
int rc, ret=OPAL_SUCCESS;
|
2014-12-05 02:18:16 +03:00
|
|
|
|
|
|
|
stop_progress_thread = 1;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* post a CQ to myself to wake my thread up
|
|
|
|
*/
|
|
|
|
|
2015-01-06 02:03:15 +03:00
|
|
|
ret = mca_btl_ugni_post_cqwrite (mca_btl_ugni_component.modules[0].local_ep,
|
|
|
|
mca_btl_ugni_component.modules[0].rdma_local_cq,
|
|
|
|
mca_btl_ugni_component.modules[0].device->smsg_irq_mhndl,
|
|
|
|
0xdead, NULL, NULL, NULL);
|
2014-12-05 02:18:16 +03:00
|
|
|
/*
|
|
|
|
* TODO: if error returned, need to kill off thread manually
|
|
|
|
*/
|
2015-01-06 02:03:15 +03:00
|
|
|
if (OPAL_SUCCESS != ret) {
|
2014-12-24 21:40:27 +03:00
|
|
|
goto fn_exit;
|
2014-12-05 02:18:16 +03:00
|
|
|
}
|
|
|
|
|
2014-12-24 21:40:27 +03:00
|
|
|
rc = pthread_mutex_lock(&progress_mutex);
|
|
|
|
if (0 != rc) {
|
|
|
|
BTL_ERROR(("btl/ugni pthread_mutex_lock returned %s ",strerror(rc)));
|
|
|
|
ret = OPAL_ERROR;
|
|
|
|
goto fn_exit;
|
|
|
|
}
|
2014-12-16 00:07:17 +03:00
|
|
|
|
2014-12-05 02:18:16 +03:00
|
|
|
while (!progress_thread_done) {
|
|
|
|
pthread_cond_wait(&progress_cond, &progress_mutex);
|
2014-12-24 21:40:27 +03:00
|
|
|
if (0 != rc) {
|
|
|
|
BTL_ERROR(("btl/ugni pthread_cond_wait returned %s ",strerror(rc)));
|
|
|
|
ret = OPAL_ERROR;
|
|
|
|
goto fn_exit;
|
|
|
|
}
|
2014-12-05 02:18:16 +03:00
|
|
|
}
|
|
|
|
|
2014-12-24 21:40:27 +03:00
|
|
|
rc = pthread_mutex_unlock(&progress_mutex);
|
|
|
|
if (0 != rc) {
|
|
|
|
BTL_ERROR(("btl/ugni pthread_mutex_unlock returned %s ",strerror(rc)));
|
|
|
|
ret = OPAL_ERROR;
|
|
|
|
goto fn_exit;
|
|
|
|
}
|
2014-12-05 02:18:16 +03:00
|
|
|
|
2014-12-24 21:40:27 +03:00
|
|
|
fn_exit:
|
|
|
|
return ret;
|
2014-12-05 02:18:16 +03:00
|
|
|
}
|
|
|
|
|