2016-06-01 16:34:03 -07:00
|
|
|
/* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil -*- */
|
|
|
|
/*
|
2016-12-31 07:37:24 -08:00
|
|
|
* Copyright (c) 2014-2017 Intel, Inc. All rights reserved.
|
2016-06-01 16:34:03 -07:00
|
|
|
* Copyright (c) 2014-2016 Research Organization for Information Science
|
|
|
|
* and Technology (RIST). All rights reserved.
|
|
|
|
* Copyright (c) 2014-2015 Mellanox Technologies, Inc.
|
|
|
|
* All rights reserved.
|
2016-08-20 07:52:25 -07:00
|
|
|
* Copyright (c) 2016 Cisco Systems, Inc. All rights reserved.
|
2016-06-01 16:34:03 -07:00
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "opal_config.h"
|
|
|
|
#include "opal/constants.h"
|
|
|
|
#include "opal/types.h"
|
|
|
|
|
|
|
|
#ifdef HAVE_STRING_H
|
|
|
|
#include <string.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_UNISTD_H
|
|
|
|
#include <unistd.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "opal/dss/dss.h"
|
|
|
|
#include "opal/mca/event/event.h"
|
|
|
|
#include "opal/mca/hwloc/base/base.h"
|
|
|
|
#include "opal/runtime/opal.h"
|
|
|
|
#include "opal/runtime/opal_progress_threads.h"
|
|
|
|
#include "opal/util/argv.h"
|
|
|
|
#include "opal/util/error.h"
|
|
|
|
#include "opal/util/output.h"
|
|
|
|
#include "opal/util/proc.h"
|
|
|
|
#include "opal/util/show_help.h"
|
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
#include "pmix2x.h"
|
2016-06-01 16:34:03 -07:00
|
|
|
#include "opal/mca/pmix/base/base.h"
|
|
|
|
#include "opal/mca/pmix/pmix_types.h"
|
|
|
|
|
2016-08-10 21:03:00 -07:00
|
|
|
#include <pmix_common.h>
|
2016-10-02 16:02:23 -07:00
|
|
|
#include <pmix.h>
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
/**** C.O.M.M.O.N I.N.T.E.R.F.A.C.E.S ****/
|
|
|
|
|
|
|
|
/* These are functions used by both client and server to
|
|
|
|
* access common functions in the embedded PMIx library */
|
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
static const char *pmix2x_get_nspace(opal_jobid_t jobid);
|
|
|
|
static void pmix2x_register_jobid(opal_jobid_t jobid, const char *nspace);
|
2016-06-01 16:34:03 -07:00
|
|
|
static void register_handler(opal_list_t *event_codes,
|
2016-08-07 20:41:54 -07:00
|
|
|
opal_list_t *info,
|
|
|
|
opal_pmix_notification_fn_t evhandler,
|
|
|
|
opal_pmix_evhandler_reg_cbfunc_t cbfunc,
|
|
|
|
void *cbdata);
|
2016-06-01 16:34:03 -07:00
|
|
|
static void deregister_handler(size_t evhandler,
|
2016-08-07 20:41:54 -07:00
|
|
|
opal_pmix_op_cbfunc_t cbfunc,
|
|
|
|
void *cbdata);
|
2016-06-01 16:34:03 -07:00
|
|
|
static int notify_event(int status,
|
2016-08-07 20:41:54 -07:00
|
|
|
const opal_process_name_t *source,
|
|
|
|
opal_pmix_data_range_t range,
|
|
|
|
opal_list_t *info,
|
|
|
|
opal_pmix_op_cbfunc_t cbfunc, void *cbdata);
|
2016-12-02 14:27:15 -08:00
|
|
|
static void pmix2x_query(opal_list_t *queries,
|
2016-10-02 16:02:23 -07:00
|
|
|
opal_pmix_info_cbfunc_t cbfunc, void *cbdata);
|
2016-12-02 14:27:15 -08:00
|
|
|
static void pmix2x_log(opal_list_t *info,
|
2016-10-02 16:02:23 -07:00
|
|
|
opal_pmix_op_cbfunc_t cbfunc, void *cbdata);
|
2016-06-01 16:34:03 -07:00
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
const opal_pmix_base_module_t opal_pmix_pmix2x_module = {
|
2016-06-01 16:34:03 -07:00
|
|
|
/* client APIs */
|
2016-12-02 14:27:15 -08:00
|
|
|
.init = pmix2x_client_init,
|
|
|
|
.finalize = pmix2x_client_finalize,
|
|
|
|
.initialized = pmix2x_initialized,
|
|
|
|
.abort = pmix2x_abort,
|
|
|
|
.commit = pmix2x_commit,
|
|
|
|
.fence = pmix2x_fence,
|
|
|
|
.fence_nb = pmix2x_fencenb,
|
|
|
|
.put = pmix2x_put,
|
|
|
|
.get = pmix2x_get,
|
|
|
|
.get_nb = pmix2x_getnb,
|
|
|
|
.publish = pmix2x_publish,
|
|
|
|
.publish_nb = pmix2x_publishnb,
|
|
|
|
.lookup = pmix2x_lookup,
|
|
|
|
.lookup_nb = pmix2x_lookupnb,
|
|
|
|
.unpublish = pmix2x_unpublish,
|
|
|
|
.unpublish_nb = pmix2x_unpublishnb,
|
|
|
|
.spawn = pmix2x_spawn,
|
|
|
|
.spawn_nb = pmix2x_spawnnb,
|
|
|
|
.connect = pmix2x_connect,
|
|
|
|
.connect_nb = pmix2x_connectnb,
|
|
|
|
.disconnect = pmix2x_disconnect,
|
|
|
|
.disconnect_nb = pmix2x_disconnectnb,
|
|
|
|
.resolve_peers = pmix2x_resolve_peers,
|
|
|
|
.resolve_nodes = pmix2x_resolve_nodes,
|
|
|
|
.query = pmix2x_query,
|
|
|
|
.log = pmix2x_log,
|
2016-06-01 16:34:03 -07:00
|
|
|
/* server APIs */
|
2016-12-02 14:27:15 -08:00
|
|
|
.server_init = pmix2x_server_init,
|
|
|
|
.server_finalize = pmix2x_server_finalize,
|
|
|
|
.generate_regex = pmix2x_server_gen_regex,
|
|
|
|
.generate_ppn = pmix2x_server_gen_ppn,
|
|
|
|
.server_register_nspace = pmix2x_server_register_nspace,
|
|
|
|
.server_deregister_nspace = pmix2x_server_deregister_nspace,
|
|
|
|
.server_register_client = pmix2x_server_register_client,
|
|
|
|
.server_deregister_client = pmix2x_server_deregister_client,
|
|
|
|
.server_setup_fork = pmix2x_server_setup_fork,
|
|
|
|
.server_dmodex_request = pmix2x_server_dmodex,
|
|
|
|
.server_notify_event = pmix2x_server_notify_event,
|
2016-06-01 16:34:03 -07:00
|
|
|
/* utility APIs */
|
|
|
|
.get_version = PMIx_Get_version,
|
|
|
|
.register_evhandler = register_handler,
|
|
|
|
.deregister_evhandler = deregister_handler,
|
|
|
|
.notify_event = notify_event,
|
2016-12-02 14:27:15 -08:00
|
|
|
.store_local = pmix2x_store_local,
|
|
|
|
.get_nspace = pmix2x_get_nspace,
|
|
|
|
.register_jobid = pmix2x_register_jobid
|
2016-06-01 16:34:03 -07:00
|
|
|
};
|
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
static const char *pmix2x_get_nspace(opal_jobid_t jobid)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
2016-12-02 14:27:15 -08:00
|
|
|
opal_pmix2x_jobid_trkr_t *jptr;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
OPAL_LIST_FOREACH(jptr, &mca_pmix_pmix2x_component.jobids, opal_pmix2x_jobid_trkr_t) {
|
2016-08-07 20:41:54 -07:00
|
|
|
if (jptr->jobid == jobid) {
|
|
|
|
return jptr->nspace;
|
|
|
|
}
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
static void pmix2x_register_jobid(opal_jobid_t jobid, const char *nspace)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
2016-12-02 14:27:15 -08:00
|
|
|
opal_pmix2x_jobid_trkr_t *jptr;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
/* if we don't already have it, add this to our jobid tracker */
|
2016-12-02 14:27:15 -08:00
|
|
|
OPAL_LIST_FOREACH(jptr, &mca_pmix_pmix2x_component.jobids, opal_pmix2x_jobid_trkr_t) {
|
2016-08-07 20:41:54 -07:00
|
|
|
if (jptr->jobid == jobid) {
|
|
|
|
return;
|
|
|
|
}
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
2016-12-02 14:27:15 -08:00
|
|
|
jptr = OBJ_NEW(opal_pmix2x_jobid_trkr_t);
|
2016-06-01 16:34:03 -07:00
|
|
|
(void)strncpy(jptr->nspace, nspace, PMIX_MAX_NSLEN);
|
|
|
|
jptr->jobid = jobid;
|
2016-12-02 14:27:15 -08:00
|
|
|
opal_list_append(&mca_pmix_pmix2x_component.jobids, &jptr->super);
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
|
2016-12-31 07:37:24 -08:00
|
|
|
static void event_hdlr_complete(pmix_status_t status, void *cbdata)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
2016-12-31 07:37:24 -08:00
|
|
|
pmix2x_opcaddy_t *op = (pmix2x_opcaddy_t*)cbdata;
|
|
|
|
|
|
|
|
OBJ_RELEASE(op);
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
|
2016-12-31 07:37:24 -08:00
|
|
|
static void return_local_event_hdlr(int status, opal_list_t *results,
|
|
|
|
opal_pmix_op_cbfunc_t cbfunc, void *thiscbdata,
|
|
|
|
void *notification_cbdata)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
2016-12-31 07:37:24 -08:00
|
|
|
pmix2x_threadshift_t *cd = (pmix2x_threadshift_t*)notification_cbdata;
|
|
|
|
pmix2x_opcaddy_t *op;
|
|
|
|
opal_value_t *kv;
|
|
|
|
pmix_status_t pstatus;
|
2016-06-01 16:34:03 -07:00
|
|
|
size_t n;
|
|
|
|
|
2016-12-31 07:37:24 -08:00
|
|
|
if (NULL != cd->pmixcbfunc) {
|
|
|
|
op = OBJ_NEW(pmix2x_opcaddy_t);
|
|
|
|
|
|
|
|
if (NULL != results) {
|
|
|
|
/* convert the list of results to an array of info */
|
|
|
|
op->ninfo = opal_list_get_size(results);
|
|
|
|
if (0 < op->ninfo) {
|
|
|
|
PMIX_INFO_CREATE(op->info, op->ninfo);
|
|
|
|
n=0;
|
|
|
|
OPAL_LIST_FOREACH(kv, cd->info, opal_value_t) {
|
|
|
|
(void)strncpy(op->info[n].key, kv->key, PMIX_MAX_KEYLEN);
|
|
|
|
pmix2x_value_load(&op->info[n].value, kv);
|
|
|
|
++n;
|
2016-08-07 20:41:54 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-12-31 07:37:24 -08:00
|
|
|
/* convert the status */
|
|
|
|
pstatus = pmix2x_convert_opalrc(status);
|
|
|
|
/* call the library's callback function */
|
|
|
|
cd->pmixcbfunc(pstatus, op->info, op->ninfo, event_hdlr_complete, op, cd->cbdata);
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
|
2016-12-31 07:37:24 -08:00
|
|
|
/* release the threadshift object */
|
|
|
|
if (NULL != cd->info) {
|
|
|
|
OPAL_LIST_RELEASE(cd->info);
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
2016-12-31 07:37:24 -08:00
|
|
|
OBJ_RELEASE(cd);
|
2016-06-01 16:34:03 -07:00
|
|
|
|
2016-12-31 07:37:24 -08:00
|
|
|
/* release the caller */
|
2016-06-01 16:34:03 -07:00
|
|
|
if (NULL != cbfunc) {
|
2016-08-07 20:41:54 -07:00
|
|
|
cbfunc(OPAL_SUCCESS, thiscbdata);
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void _event_hdlr(int sd, short args, void *cbdata)
|
|
|
|
{
|
2016-12-02 14:27:15 -08:00
|
|
|
pmix2x_threadshift_t *cd = (pmix2x_threadshift_t*)cbdata;
|
2016-12-31 07:37:24 -08:00
|
|
|
opal_pmix2x_event_t *event;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
opal_output_verbose(2, opal_pmix_base_framework.framework_output,
|
2016-12-31 07:37:24 -08:00
|
|
|
"%s _EVENT_HDLR RECEIVED NOTIFICATION FOR HANDLER %d OF STATUS %d",
|
|
|
|
OPAL_NAME_PRINT(OPAL_PROC_MY_NAME), (int)cd->id, cd->status);
|
|
|
|
|
|
|
|
/* cycle thru the registrations */
|
|
|
|
OPAL_LIST_FOREACH(event, &mca_pmix_pmix2x_component.events, opal_pmix2x_event_t) {
|
|
|
|
if (cd->id == event->index) {
|
2016-08-07 20:41:54 -07:00
|
|
|
/* found it - invoke the handler, pointing its
|
2016-12-31 07:37:24 -08:00
|
|
|
* callback function to our callback function */
|
2016-08-07 20:41:54 -07:00
|
|
|
opal_output_verbose(2, opal_pmix_base_framework.framework_output,
|
2016-12-31 07:37:24 -08:00
|
|
|
"%s _EVENT_HDLR CALLING EVHDLR",
|
2016-08-07 20:41:54 -07:00
|
|
|
OPAL_NAME_PRINT(OPAL_PROC_MY_NAME));
|
2016-12-31 07:37:24 -08:00
|
|
|
event->handler(cd->status, &cd->pname,
|
|
|
|
cd->info, &cd->results,
|
|
|
|
return_local_event_hdlr, (void*)cd);
|
2016-08-07 20:41:54 -07:00
|
|
|
return;
|
|
|
|
}
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
2016-12-31 07:37:24 -08:00
|
|
|
/* if we didn't find a match, we still have to call their final callback */
|
|
|
|
if (NULL != cd->pmixcbfunc) {
|
|
|
|
cd->pmixcbfunc(PMIX_SUCCESS, NULL, 0, NULL, NULL, cd->cbdata);
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* this function will be called by the PMIx client library
|
|
|
|
* whenever it receives notification of an event. The
|
|
|
|
* notification can come from an ORTE daemon (when launched
|
|
|
|
* by mpirun), directly from a RM (when direct launched), or
|
|
|
|
* from another process (via the local daemon).
|
|
|
|
* The call will occur in the PMIx event base */
|
2016-12-02 14:27:15 -08:00
|
|
|
void pmix2x_event_hdlr(size_t evhdlr_registration_id,
|
2016-08-07 20:41:54 -07:00
|
|
|
pmix_status_t status, const pmix_proc_t *source,
|
|
|
|
pmix_info_t info[], size_t ninfo,
|
|
|
|
pmix_info_t results[], size_t nresults,
|
|
|
|
pmix_event_notification_cbfunc_fn_t cbfunc,
|
|
|
|
void *cbdata)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
2016-12-02 14:27:15 -08:00
|
|
|
pmix2x_threadshift_t *cd;
|
2016-06-01 16:34:03 -07:00
|
|
|
int rc;
|
|
|
|
opal_value_t *iptr;
|
|
|
|
size_t n;
|
|
|
|
|
|
|
|
/* this is in the PMIx local thread - need to threadshift to
|
|
|
|
* our own thread as we will be accessing framework-global
|
|
|
|
* lists and objects */
|
|
|
|
|
|
|
|
opal_output_verbose(2, opal_pmix_base_framework.framework_output,
|
2016-08-07 20:41:54 -07:00
|
|
|
"%s RECEIVED NOTIFICATION OF STATUS %d",
|
|
|
|
OPAL_NAME_PRINT(OPAL_PROC_MY_NAME), status);
|
2016-06-01 16:34:03 -07:00
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
cd = OBJ_NEW(pmix2x_threadshift_t);
|
2016-12-31 07:37:24 -08:00
|
|
|
cd->id = evhdlr_registration_id;
|
|
|
|
cd->pmixcbfunc = cbfunc;
|
|
|
|
cd->cbdata = cbdata;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
/* convert the incoming status */
|
2016-12-02 14:27:15 -08:00
|
|
|
cd->status = pmix2x_convert_rc(status);
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_output_verbose(2, opal_pmix_base_framework.framework_output,
|
2016-08-07 20:41:54 -07:00
|
|
|
"%s CONVERTED STATUS %d TO STATUS %d",
|
|
|
|
OPAL_NAME_PRINT(OPAL_PROC_MY_NAME), status, cd->status);
|
2016-10-13 15:25:16 -07:00
|
|
|
|
2016-06-01 16:34:03 -07:00
|
|
|
/* convert the nspace/rank to an opal_process_name_t */
|
|
|
|
if (NULL == source) {
|
2016-08-07 20:41:54 -07:00
|
|
|
cd->pname.jobid = OPAL_NAME_INVALID->jobid;
|
|
|
|
cd->pname.vpid = OPAL_NAME_INVALID->vpid;
|
2016-06-01 16:34:03 -07:00
|
|
|
} else {
|
2016-08-07 20:41:54 -07:00
|
|
|
if (OPAL_SUCCESS != (rc = opal_convert_string_to_jobid(&cd->pname.jobid, source->nspace))) {
|
|
|
|
OPAL_ERROR_LOG(rc);
|
|
|
|
OBJ_RELEASE(cd);
|
|
|
|
return;
|
|
|
|
}
|
2016-12-02 14:27:15 -08:00
|
|
|
cd->pname.vpid = pmix2x_convert_rank(source->rank);
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
/* convert the array of info */
|
|
|
|
if (NULL != info) {
|
2016-08-07 20:41:54 -07:00
|
|
|
cd->info = OBJ_NEW(opal_list_t);
|
|
|
|
for (n=0; n < ninfo; n++) {
|
|
|
|
iptr = OBJ_NEW(opal_value_t);
|
|
|
|
iptr->key = strdup(info[n].key);
|
2016-12-02 14:27:15 -08:00
|
|
|
if (OPAL_SUCCESS != (rc = pmix2x_value_unload(iptr, &info[n].value))) {
|
2016-08-07 20:41:54 -07:00
|
|
|
OPAL_ERROR_LOG(rc);
|
|
|
|
OBJ_RELEASE(iptr);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
opal_list_append(cd->info, &iptr->super);
|
|
|
|
}
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
2016-12-31 07:37:24 -08:00
|
|
|
|
|
|
|
/* convert the array of prior results */
|
|
|
|
if (NULL != results) {
|
|
|
|
for (n=0; n < nresults; n++) {
|
|
|
|
iptr = OBJ_NEW(opal_value_t);
|
|
|
|
iptr->key = strdup(results[n].key);
|
|
|
|
if (OPAL_SUCCESS != (rc = pmix2x_value_unload(iptr, &results[n].value))) {
|
|
|
|
OPAL_ERROR_LOG(rc);
|
|
|
|
OBJ_RELEASE(iptr);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
opal_list_append(&cd->results, &iptr->super);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-01 16:34:03 -07:00
|
|
|
/* now push it into the local thread */
|
|
|
|
event_assign(&cd->ev, opal_pmix_base.evbase,
|
2016-08-07 20:41:54 -07:00
|
|
|
-1, EV_WRITE, _event_hdlr, cd);
|
2016-06-01 16:34:03 -07:00
|
|
|
event_active(&cd->ev, EV_WRITE, 1);
|
|
|
|
}
|
|
|
|
|
2016-12-26 13:35:17 +09:00
|
|
|
opal_vpid_t pmix2x_convert_rank(pmix_rank_t rank)
|
2016-07-19 20:10:58 -07:00
|
|
|
{
|
|
|
|
switch(rank) {
|
|
|
|
case PMIX_RANK_UNDEF:
|
|
|
|
return OPAL_VPID_INVALID;
|
|
|
|
case PMIX_RANK_WILDCARD:
|
|
|
|
return OPAL_VPID_WILDCARD;
|
|
|
|
default:
|
|
|
|
return (opal_vpid_t)rank;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
pmix_rank_t pmix2x_convert_opalrank(opal_vpid_t vpid)
|
2016-07-19 20:10:58 -07:00
|
|
|
{
|
|
|
|
switch(vpid) {
|
|
|
|
case OPAL_VPID_WILDCARD:
|
|
|
|
return PMIX_RANK_WILDCARD;
|
|
|
|
case OPAL_VPID_INVALID:
|
|
|
|
return PMIX_RANK_UNDEF;
|
|
|
|
default:
|
2016-08-07 20:41:54 -07:00
|
|
|
return (pmix_rank_t)vpid;
|
2016-07-19 20:10:58 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
pmix_status_t pmix2x_convert_opalrc(int rc)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
|
|
|
switch (rc) {
|
|
|
|
case OPAL_ERR_DEBUGGER_RELEASE:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_ERR_DEBUGGER_RELEASE;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
2016-07-13 13:28:56 -07:00
|
|
|
case OPAL_ERR_HANDLERS_COMPLETE:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_EVENT_ACTION_COMPLETE;
|
2016-07-13 13:28:56 -07:00
|
|
|
|
|
|
|
case OPAL_ERR_PROC_ABORTED:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_ERR_PROC_ABORTED;
|
2016-07-13 13:28:56 -07:00
|
|
|
|
|
|
|
case OPAL_ERR_PROC_REQUESTED_ABORT:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_ERR_PROC_REQUESTED_ABORT;
|
2016-07-13 13:28:56 -07:00
|
|
|
|
|
|
|
case OPAL_ERR_PROC_ABORTING:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_ERR_PROC_ABORTING;
|
2016-07-13 13:28:56 -07:00
|
|
|
|
|
|
|
case OPAL_ERR_NODE_DOWN:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_ERR_NODE_DOWN;
|
2016-07-13 13:28:56 -07:00
|
|
|
|
|
|
|
case OPAL_ERR_NODE_OFFLINE:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_ERR_NODE_OFFLINE;
|
2016-07-13 13:28:56 -07:00
|
|
|
|
2016-09-01 11:41:13 -07:00
|
|
|
case OPAL_ERR_JOB_TERMINATED:
|
|
|
|
return PMIX_ERR_JOB_TERMINATED;
|
|
|
|
|
|
|
|
case OPAL_ERR_PROC_RESTART:
|
|
|
|
return PMIX_ERR_PROC_RESTART;
|
|
|
|
|
|
|
|
case OPAL_ERR_PROC_CHECKPOINT:
|
|
|
|
return PMIX_ERR_PROC_CHECKPOINT;
|
|
|
|
|
|
|
|
case OPAL_ERR_PROC_MIGRATE:
|
|
|
|
return PMIX_ERR_PROC_MIGRATE;
|
|
|
|
|
|
|
|
case OPAL_ERR_EVENT_REGISTRATION:
|
|
|
|
return PMIX_ERR_EVENT_REGISTRATION;
|
|
|
|
|
2016-06-01 16:34:03 -07:00
|
|
|
case OPAL_ERR_NOT_IMPLEMENTED:
|
|
|
|
case OPAL_ERR_NOT_SUPPORTED:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_ERR_NOT_SUPPORTED;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
case OPAL_ERR_NOT_FOUND:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_ERR_NOT_FOUND;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
case OPAL_ERR_PERM:
|
|
|
|
case OPAL_ERR_UNREACH:
|
|
|
|
case OPAL_ERR_SERVER_NOT_AVAIL:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_ERR_UNREACH;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
case OPAL_ERR_BAD_PARAM:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_ERR_BAD_PARAM;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
case OPAL_ERR_OUT_OF_RESOURCE:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_ERR_OUT_OF_RESOURCE;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
case OPAL_ERR_DATA_VALUE_NOT_FOUND:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_ERR_DATA_VALUE_NOT_FOUND;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
case OPAL_ERR_TIMEOUT:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_ERR_TIMEOUT;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
case OPAL_ERR_WOULD_BLOCK:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_ERR_WOULD_BLOCK;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
case OPAL_EXISTS:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_EXISTS;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
2016-07-13 13:28:56 -07:00
|
|
|
case OPAL_ERR_PARTIAL_SUCCESS:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_QUERY_PARTIAL_SUCCESS;
|
2016-07-13 13:28:56 -07:00
|
|
|
|
2016-06-01 16:34:03 -07:00
|
|
|
case OPAL_ERROR:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_ERROR;
|
2016-06-01 16:34:03 -07:00
|
|
|
case OPAL_SUCCESS:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_SUCCESS;
|
2016-06-01 16:34:03 -07:00
|
|
|
default:
|
2016-12-31 07:37:24 -08:00
|
|
|
return rc;
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
int pmix2x_convert_rc(pmix_status_t rc)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
|
|
|
switch (rc) {
|
|
|
|
case PMIX_ERR_DEBUGGER_RELEASE:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_ERR_DEBUGGER_RELEASE;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
2016-07-13 13:28:56 -07:00
|
|
|
case PMIX_EVENT_ACTION_COMPLETE:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_ERR_HANDLERS_COMPLETE;
|
2016-07-13 13:28:56 -07:00
|
|
|
|
|
|
|
case PMIX_ERR_PROC_ABORTED:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_ERR_PROC_ABORTED;
|
2016-07-13 13:28:56 -07:00
|
|
|
|
|
|
|
case PMIX_ERR_PROC_REQUESTED_ABORT:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_ERR_PROC_REQUESTED_ABORT;
|
2016-07-13 13:28:56 -07:00
|
|
|
|
|
|
|
case PMIX_ERR_PROC_ABORTING:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_ERR_PROC_ABORTING;
|
2016-07-13 13:28:56 -07:00
|
|
|
|
|
|
|
case PMIX_ERR_NODE_DOWN:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_ERR_NODE_DOWN;
|
2016-07-13 13:28:56 -07:00
|
|
|
|
|
|
|
case PMIX_ERR_NODE_OFFLINE:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_ERR_NODE_OFFLINE;
|
2016-07-13 13:28:56 -07:00
|
|
|
|
2016-09-01 11:41:13 -07:00
|
|
|
case PMIX_ERR_JOB_TERMINATED:
|
|
|
|
return OPAL_ERR_JOB_TERMINATED;
|
|
|
|
|
|
|
|
case PMIX_ERR_PROC_RESTART:
|
|
|
|
return OPAL_ERR_PROC_RESTART;
|
|
|
|
|
|
|
|
case PMIX_ERR_PROC_CHECKPOINT:
|
|
|
|
return OPAL_ERR_PROC_CHECKPOINT;
|
|
|
|
|
|
|
|
case PMIX_ERR_PROC_MIGRATE:
|
|
|
|
return OPAL_ERR_PROC_MIGRATE;
|
|
|
|
|
|
|
|
case PMIX_ERR_EVENT_REGISTRATION:
|
|
|
|
return OPAL_ERR_EVENT_REGISTRATION;
|
|
|
|
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_ERR_NOT_SUPPORTED:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_ERR_NOT_SUPPORTED;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
case PMIX_ERR_NOT_FOUND:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_ERR_NOT_FOUND;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
case PMIX_ERR_OUT_OF_RESOURCE:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_ERR_OUT_OF_RESOURCE;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
case PMIX_ERR_INIT:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_ERROR;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
case PMIX_ERR_BAD_PARAM:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_ERR_BAD_PARAM;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
case PMIX_ERR_UNREACH:
|
|
|
|
case PMIX_ERR_NO_PERMISSIONS:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_ERR_UNREACH;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
case PMIX_ERR_TIMEOUT:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_ERR_TIMEOUT;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
case PMIX_ERR_WOULD_BLOCK:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_ERR_WOULD_BLOCK;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
case PMIX_ERR_LOST_CONNECTION_TO_SERVER:
|
|
|
|
case PMIX_ERR_LOST_PEER_CONNECTION:
|
|
|
|
case PMIX_ERR_LOST_CONNECTION_TO_CLIENT:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_ERR_COMM_FAILURE;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
case PMIX_EXISTS:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_EXISTS;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
2016-07-13 13:28:56 -07:00
|
|
|
case PMIX_QUERY_PARTIAL_SUCCESS:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_ERR_PARTIAL_SUCCESS;
|
2016-07-13 13:28:56 -07:00
|
|
|
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_ERROR:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_ERROR;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_SUCCESS:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_SUCCESS;
|
2016-06-01 16:34:03 -07:00
|
|
|
default:
|
2016-12-31 07:37:24 -08:00
|
|
|
return rc;
|
2016-08-07 20:41:54 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
opal_pmix_scope_t pmix2x_convert_scope(pmix_scope_t scope)
|
2016-08-07 20:41:54 -07:00
|
|
|
{
|
|
|
|
switch(scope) {
|
|
|
|
case PMIX_SCOPE_UNDEF:
|
|
|
|
return OPAL_PMIX_SCOPE_UNDEF;
|
|
|
|
case PMIX_LOCAL:
|
|
|
|
return OPAL_PMIX_LOCAL;
|
|
|
|
case PMIX_REMOTE:
|
|
|
|
return OPAL_PMIX_REMOTE;
|
|
|
|
case PMIX_GLOBAL:
|
|
|
|
return OPAL_PMIX_GLOBAL;
|
|
|
|
default:
|
|
|
|
return OPAL_PMIX_SCOPE_UNDEF;
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
pmix_scope_t pmix2x_convert_opalscope(opal_pmix_scope_t scope) {
|
2016-06-01 16:34:03 -07:00
|
|
|
switch(scope) {
|
|
|
|
case OPAL_PMIX_LOCAL:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_LOCAL;
|
2016-06-01 16:34:03 -07:00
|
|
|
case OPAL_PMIX_REMOTE:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_REMOTE;
|
2016-06-01 16:34:03 -07:00
|
|
|
case OPAL_PMIX_GLOBAL:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_GLOBAL;
|
2016-06-01 16:34:03 -07:00
|
|
|
default:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_SCOPE_UNDEF;
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
pmix_data_range_t pmix2x_convert_opalrange(opal_pmix_data_range_t range) {
|
2016-06-01 16:34:03 -07:00
|
|
|
switch(range) {
|
|
|
|
case OPAL_PMIX_RANGE_UNDEF:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_RANGE_UNDEF;
|
2016-06-01 16:34:03 -07:00
|
|
|
case OPAL_PMIX_RANGE_LOCAL:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_RANGE_LOCAL;
|
2016-06-01 16:34:03 -07:00
|
|
|
case OPAL_PMIX_RANGE_NAMESPACE:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_RANGE_NAMESPACE;
|
2016-06-01 16:34:03 -07:00
|
|
|
case OPAL_PMIX_RANGE_SESSION:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_RANGE_SESSION;
|
2016-06-01 16:34:03 -07:00
|
|
|
case OPAL_PMIX_RANGE_GLOBAL:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_RANGE_GLOBAL;
|
2016-06-01 16:34:03 -07:00
|
|
|
case OPAL_PMIX_RANGE_CUSTOM:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_RANGE_CUSTOM;
|
2016-06-01 16:34:03 -07:00
|
|
|
default:
|
2016-08-07 20:41:54 -07:00
|
|
|
return PMIX_SCOPE_UNDEF;
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
opal_pmix_data_range_t pmix2x_convert_range(pmix_data_range_t range) {
|
2016-06-01 16:34:03 -07:00
|
|
|
switch(range) {
|
|
|
|
case PMIX_RANGE_UNDEF:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_PMIX_RANGE_UNDEF;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_RANGE_LOCAL:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_PMIX_RANGE_LOCAL;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_RANGE_NAMESPACE:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_PMIX_RANGE_NAMESPACE;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_RANGE_SESSION:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_PMIX_RANGE_SESSION;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_RANGE_GLOBAL:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_PMIX_RANGE_GLOBAL;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_RANGE_CUSTOM:
|
2016-08-07 20:41:54 -07:00
|
|
|
return OPAL_PMIX_RANGE_CUSTOM;
|
2016-06-01 16:34:03 -07:00
|
|
|
default:
|
2016-10-23 11:36:05 -07:00
|
|
|
return OPAL_PMIX_RANGE_UNDEF;
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
opal_pmix_persistence_t pmix2x_convert_persist(pmix_persistence_t persist)
|
2016-08-07 20:41:54 -07:00
|
|
|
{
|
|
|
|
switch(persist) {
|
|
|
|
case PMIX_PERSIST_INDEF:
|
|
|
|
return OPAL_PMIX_PERSIST_INDEF;
|
|
|
|
case PMIX_PERSIST_FIRST_READ:
|
|
|
|
return OPAL_PMIX_PERSIST_FIRST_READ;
|
|
|
|
case PMIX_PERSIST_PROC:
|
|
|
|
return OPAL_PMIX_PERSIST_PROC;
|
|
|
|
case PMIX_PERSIST_APP:
|
|
|
|
return OPAL_PMIX_PERSIST_APP;
|
|
|
|
case PMIX_PERSIST_SESSION:
|
|
|
|
return OPAL_PMIX_PERSIST_SESSION;
|
|
|
|
default:
|
|
|
|
return OPAL_PMIX_PERSIST_INDEF;
|
|
|
|
}
|
|
|
|
}
|
2016-06-01 16:34:03 -07:00
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
pmix_persistence_t pmix2x_convert_opalpersist(opal_pmix_persistence_t persist)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
2016-08-07 20:41:54 -07:00
|
|
|
switch(persist) {
|
|
|
|
case OPAL_PMIX_PERSIST_INDEF:
|
|
|
|
return PMIX_PERSIST_INDEF;
|
|
|
|
case OPAL_PMIX_PERSIST_FIRST_READ:
|
|
|
|
return PMIX_PERSIST_FIRST_READ;
|
|
|
|
case OPAL_PMIX_PERSIST_PROC:
|
|
|
|
return PMIX_PERSIST_PROC;
|
|
|
|
case OPAL_PMIX_PERSIST_APP:
|
|
|
|
return PMIX_PERSIST_APP;
|
|
|
|
case OPAL_PMIX_PERSIST_SESSION:
|
|
|
|
return PMIX_PERSIST_SESSION;
|
|
|
|
default:
|
|
|
|
return PMIX_PERSIST_INDEF;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**** RHC: NEED TO ADD SUPPORT FOR NEW PMIX DATA TYPES, INCLUDING
|
|
|
|
**** CONVERSION OF PROC STATES ****/
|
2016-06-17 15:15:13 -07:00
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
void pmix2x_value_load(pmix_value_t *v,
|
2016-08-07 20:41:54 -07:00
|
|
|
opal_value_t *kv)
|
|
|
|
{
|
2016-12-19 00:34:27 -08:00
|
|
|
opal_pmix2x_jobid_trkr_t *job;
|
|
|
|
bool found;
|
2016-12-31 07:37:24 -08:00
|
|
|
opal_list_t *list;
|
|
|
|
opal_value_t *val;
|
|
|
|
pmix_info_t *info;
|
|
|
|
size_t n;
|
2016-12-19 00:34:27 -08:00
|
|
|
|
2016-06-01 16:34:03 -07:00
|
|
|
switch(kv->type) {
|
2016-08-07 20:41:54 -07:00
|
|
|
case OPAL_UNDEF:
|
|
|
|
v->type = PMIX_UNDEF;
|
|
|
|
break;
|
|
|
|
case OPAL_BOOL:
|
|
|
|
v->type = PMIX_BOOL;
|
|
|
|
memcpy(&(v->data.flag), &kv->data.flag, 1);
|
|
|
|
break;
|
|
|
|
case OPAL_BYTE:
|
|
|
|
v->type = PMIX_BYTE;
|
|
|
|
memcpy(&(v->data.byte), &kv->data.byte, 1);
|
|
|
|
break;
|
|
|
|
case OPAL_STRING:
|
|
|
|
v->type = PMIX_STRING;
|
|
|
|
if (NULL != kv->data.string) {
|
|
|
|
v->data.string = strdup(kv->data.string);
|
|
|
|
} else {
|
|
|
|
v->data.string = NULL;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case OPAL_SIZE:
|
|
|
|
v->type = PMIX_SIZE;
|
|
|
|
v->data.size = (size_t)kv->data.size;
|
|
|
|
break;
|
|
|
|
case OPAL_PID:
|
|
|
|
v->type = PMIX_PID;
|
|
|
|
memcpy(&(v->data.pid), &kv->data.pid, sizeof(pid_t));
|
|
|
|
break;
|
|
|
|
case OPAL_INT:
|
|
|
|
v->type = PMIX_INT;
|
|
|
|
memcpy(&(v->data.integer), &kv->data.integer, sizeof(int));
|
|
|
|
break;
|
|
|
|
case OPAL_INT8:
|
|
|
|
v->type = PMIX_INT8;
|
|
|
|
memcpy(&(v->data.int8), &kv->data.int8, 1);
|
|
|
|
break;
|
|
|
|
case OPAL_INT16:
|
|
|
|
v->type = PMIX_INT16;
|
|
|
|
memcpy(&(v->data.int16), &kv->data.int16, 2);
|
|
|
|
break;
|
|
|
|
case OPAL_INT32:
|
|
|
|
v->type = PMIX_INT32;
|
|
|
|
memcpy(&(v->data.int32), &kv->data.int32, 4);
|
|
|
|
break;
|
|
|
|
case OPAL_INT64:
|
|
|
|
v->type = PMIX_INT64;
|
|
|
|
memcpy(&(v->data.int64), &kv->data.int64, 8);
|
|
|
|
break;
|
|
|
|
case OPAL_UINT:
|
|
|
|
v->type = PMIX_UINT;
|
|
|
|
memcpy(&(v->data.uint), &kv->data.uint, sizeof(int));
|
|
|
|
break;
|
|
|
|
case OPAL_UINT8:
|
|
|
|
v->type = PMIX_UINT8;
|
|
|
|
memcpy(&(v->data.uint8), &kv->data.uint8, 1);
|
|
|
|
break;
|
|
|
|
case OPAL_UINT16:
|
|
|
|
v->type = PMIX_UINT16;
|
|
|
|
memcpy(&(v->data.uint16), &kv->data.uint16, 2);
|
|
|
|
break;
|
|
|
|
case OPAL_UINT32:
|
|
|
|
v->type = PMIX_UINT32;
|
|
|
|
memcpy(&(v->data.uint32), &kv->data.uint32, 4);
|
|
|
|
break;
|
|
|
|
case OPAL_UINT64:
|
|
|
|
v->type = PMIX_UINT64;
|
|
|
|
memcpy(&(v->data.uint64), &kv->data.uint64, 8);
|
|
|
|
break;
|
|
|
|
case OPAL_FLOAT:
|
|
|
|
v->type = PMIX_FLOAT;
|
|
|
|
memcpy(&(v->data.fval), &kv->data.fval, sizeof(float));
|
|
|
|
break;
|
|
|
|
case OPAL_DOUBLE:
|
|
|
|
v->type = PMIX_DOUBLE;
|
|
|
|
memcpy(&(v->data.dval), &kv->data.dval, sizeof(double));
|
|
|
|
break;
|
|
|
|
case OPAL_TIMEVAL:
|
|
|
|
v->type = PMIX_TIMEVAL;
|
|
|
|
memcpy(&(v->data.tv), &kv->data.tv, sizeof(struct timeval));
|
|
|
|
break;
|
|
|
|
case OPAL_TIME:
|
|
|
|
v->type = PMIX_TIME;
|
|
|
|
memcpy(&(v->data.time), &kv->data.time, sizeof(time_t));
|
|
|
|
break;
|
|
|
|
case OPAL_STATUS:
|
|
|
|
v->type = PMIX_STATUS;
|
|
|
|
memcpy(&(v->data.status), &kv->data.status, sizeof(pmix_status_t));
|
|
|
|
break;
|
|
|
|
case OPAL_VPID:
|
|
|
|
v->type = PMIX_PROC_RANK;
|
2016-12-02 14:27:15 -08:00
|
|
|
v->data.rank = pmix2x_convert_opalrank(kv->data.name.vpid);
|
2016-08-07 20:41:54 -07:00
|
|
|
break;
|
|
|
|
case OPAL_NAME:
|
|
|
|
v->type = PMIX_PROC;
|
|
|
|
/* have to stringify the jobid */
|
2016-08-20 07:52:25 -07:00
|
|
|
PMIX_PROC_CREATE(v->data.proc, 1);
|
2016-12-19 00:34:27 -08:00
|
|
|
/* see if this job is in our list of known nspaces */
|
|
|
|
found = false;
|
|
|
|
OPAL_LIST_FOREACH(job, &mca_pmix_pmix2x_component.jobids, opal_pmix2x_jobid_trkr_t) {
|
|
|
|
if (job->jobid == kv->data.name.jobid) {
|
|
|
|
(void)strncpy(v->data.proc->nspace, job->nspace, PMIX_MAX_NSLEN);
|
|
|
|
found = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!found) {
|
|
|
|
(void)opal_snprintf_jobid(v->data.proc->nspace, PMIX_MAX_NSLEN, kv->data.name.vpid);
|
|
|
|
}
|
2016-12-02 14:27:15 -08:00
|
|
|
v->data.proc->rank = pmix2x_convert_opalrank(kv->data.name.vpid);
|
2016-08-07 20:41:54 -07:00
|
|
|
break;
|
|
|
|
case OPAL_BYTE_OBJECT:
|
|
|
|
v->type = PMIX_BYTE_OBJECT;
|
|
|
|
if (NULL != kv->data.bo.bytes) {
|
|
|
|
v->data.bo.bytes = (char*)malloc(kv->data.bo.size);
|
|
|
|
memcpy(v->data.bo.bytes, kv->data.bo.bytes, kv->data.bo.size);
|
|
|
|
v->data.bo.size = (size_t)kv->data.bo.size;
|
|
|
|
} else {
|
|
|
|
v->data.bo.bytes = NULL;
|
|
|
|
v->data.bo.size = 0;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case OPAL_PERSIST:
|
|
|
|
v->type = PMIX_PERSIST;
|
2016-12-26 13:35:17 +09:00
|
|
|
v->data.persist = pmix2x_convert_opalpersist((opal_pmix_persistence_t)kv->data.uint8);
|
2016-08-07 20:41:54 -07:00
|
|
|
break;
|
|
|
|
case OPAL_SCOPE:
|
|
|
|
v->type = PMIX_SCOPE;
|
2016-12-26 13:35:17 +09:00
|
|
|
v->data.scope = pmix2x_convert_opalscope((opal_pmix_scope_t)kv->data.uint8);
|
2016-08-07 20:41:54 -07:00
|
|
|
break;
|
|
|
|
case OPAL_DATA_RANGE:
|
|
|
|
v->type = PMIX_DATA_RANGE;
|
2016-12-26 13:35:17 +09:00
|
|
|
v->data.range = pmix2x_convert_opalrange((opal_pmix_data_range_t)kv->data.uint8);
|
2016-08-07 20:41:54 -07:00
|
|
|
break;
|
|
|
|
case OPAL_PROC_STATE:
|
|
|
|
v->type = PMIX_PROC_STATE;
|
|
|
|
/* the OPAL layer doesn't have any concept of proc state,
|
|
|
|
* so the ORTE layer is responsible for converting it */
|
|
|
|
memcpy(&v->data.state, &kv->data.uint8, sizeof(uint8_t));
|
|
|
|
break;
|
2016-08-12 21:04:32 -07:00
|
|
|
case OPAL_PTR:
|
2016-12-31 07:37:24 -08:00
|
|
|
/* if someone returned a pointer, it must be to a list of
|
|
|
|
* opal_value_t's that we need to convert to a pmix_data_array
|
|
|
|
* of pmix_info_t structures */
|
|
|
|
list = (opal_list_t*)kv->data.ptr;
|
|
|
|
v->type = PMIX_DATA_ARRAY;
|
|
|
|
v->data.darray = (pmix_data_array_t*)malloc(sizeof(pmix_data_array_t));
|
|
|
|
v->data.darray->type = PMIX_INFO;
|
|
|
|
v->data.darray->size = opal_list_get_size(list);
|
|
|
|
PMIX_INFO_CREATE(info, v->data.darray->size);
|
|
|
|
v->data.darray->array = info;
|
|
|
|
n=0;
|
|
|
|
OPAL_LIST_FOREACH(val, list, opal_value_t) {
|
|
|
|
(void)strncpy(info[n].key, val->key, PMIX_MAX_KEYLEN);
|
|
|
|
pmix2x_value_load(&info[n].value, val);
|
|
|
|
++n;
|
|
|
|
}
|
2016-08-12 21:04:32 -07:00
|
|
|
break;
|
2016-08-07 20:41:54 -07:00
|
|
|
default:
|
|
|
|
/* silence warnings */
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
int pmix2x_value_unload(opal_value_t *kv,
|
2016-08-07 20:41:54 -07:00
|
|
|
const pmix_value_t *v)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
|
|
|
int rc=OPAL_SUCCESS;
|
2016-12-19 00:34:27 -08:00
|
|
|
bool found;
|
|
|
|
opal_pmix2x_jobid_trkr_t *job;
|
2017-01-05 09:46:05 -08:00
|
|
|
opal_list_t *lt;
|
|
|
|
opal_value_t *ival;
|
|
|
|
size_t n;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
switch(v->type) {
|
|
|
|
case PMIX_UNDEF:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_UNDEF;
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_BOOL:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_BOOL;
|
|
|
|
memcpy(&kv->data.flag, &(v->data.flag), 1);
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_BYTE:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_BYTE;
|
|
|
|
memcpy(&kv->data.byte, &(v->data.byte), 1);
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_STRING:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_STRING;
|
|
|
|
if (NULL != v->data.string) {
|
|
|
|
kv->data.string = strdup(v->data.string);
|
|
|
|
}
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_SIZE:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_SIZE;
|
|
|
|
kv->data.size = (int)v->data.size;
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_PID:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_PID;
|
|
|
|
memcpy(&kv->data.pid, &(v->data.pid), sizeof(pid_t));
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_INT:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_INT;
|
|
|
|
memcpy(&kv->data.integer, &(v->data.integer), sizeof(int));
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_INT8:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_INT8;
|
|
|
|
memcpy(&kv->data.int8, &(v->data.int8), 1);
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_INT16:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_INT16;
|
|
|
|
memcpy(&kv->data.int16, &(v->data.int16), 2);
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_INT32:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_INT32;
|
|
|
|
memcpy(&kv->data.int32, &(v->data.int32), 4);
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_INT64:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_INT64;
|
|
|
|
memcpy(&kv->data.int64, &(v->data.int64), 8);
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_UINT:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_UINT;
|
|
|
|
memcpy(&kv->data.uint, &(v->data.uint), sizeof(int));
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_UINT8:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_UINT8;
|
|
|
|
memcpy(&kv->data.uint8, &(v->data.uint8), 1);
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_UINT16:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_UINT16;
|
|
|
|
memcpy(&kv->data.uint16, &(v->data.uint16), 2);
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_UINT32:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_UINT32;
|
|
|
|
memcpy(&kv->data.uint32, &(v->data.uint32), 4);
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_UINT64:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_UINT64;
|
|
|
|
memcpy(&kv->data.uint64, &(v->data.uint64), 8);
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_FLOAT:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_FLOAT;
|
|
|
|
memcpy(&kv->data.fval, &(v->data.fval), sizeof(float));
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_DOUBLE:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_DOUBLE;
|
|
|
|
memcpy(&kv->data.dval, &(v->data.dval), sizeof(double));
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
case PMIX_TIMEVAL:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_TIMEVAL;
|
|
|
|
memcpy(&kv->data.tv, &(v->data.tv), sizeof(struct timeval));
|
|
|
|
break;
|
|
|
|
case PMIX_TIME:
|
|
|
|
kv->type = OPAL_TIME;
|
2016-08-25 08:05:03 -07:00
|
|
|
memcpy(&kv->data.time, &(v->data.time), sizeof(time_t));
|
2016-08-07 20:41:54 -07:00
|
|
|
break;
|
|
|
|
case PMIX_STATUS:
|
|
|
|
kv->type = OPAL_STATUS;
|
|
|
|
memcpy(&kv->data.status, &(v->data.status), sizeof(opal_status_t));
|
|
|
|
break;
|
|
|
|
case PMIX_PROC_RANK:
|
|
|
|
kv->type = OPAL_VPID;
|
2016-12-02 14:27:15 -08:00
|
|
|
kv->data.name.vpid = pmix2x_convert_rank(v->data.rank);
|
2016-08-07 20:41:54 -07:00
|
|
|
break;
|
2016-07-13 13:28:56 -07:00
|
|
|
case PMIX_PROC:
|
2016-08-07 20:41:54 -07:00
|
|
|
kv->type = OPAL_NAME;
|
2016-12-19 00:34:27 -08:00
|
|
|
/* see if this job is in our list of known nspaces */
|
|
|
|
found = false;
|
|
|
|
OPAL_LIST_FOREACH(job, &mca_pmix_pmix2x_component.jobids, opal_pmix2x_jobid_trkr_t) {
|
|
|
|
if (0 == strncmp(job->nspace, v->data.proc->nspace, PMIX_MAX_NSLEN)) {
|
|
|
|
kv->data.name.jobid = job->jobid;
|
|
|
|
found = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!found) {
|
|
|
|
if (OPAL_SUCCESS != (rc = opal_convert_string_to_jobid(&kv->data.name.jobid, v->data.proc->nspace))) {
|
|
|
|
return pmix2x_convert_opalrc(rc);
|
|
|
|
}
|
2016-08-07 20:41:54 -07:00
|
|
|
}
|
2016-12-02 14:27:15 -08:00
|
|
|
kv->data.name.vpid = pmix2x_convert_rank(v->data.proc->rank);
|
2016-08-07 20:41:54 -07:00
|
|
|
break;
|
|
|
|
case PMIX_BYTE_OBJECT:
|
|
|
|
kv->type = OPAL_BYTE_OBJECT;
|
|
|
|
if (NULL != v->data.bo.bytes && 0 < v->data.bo.size) {
|
|
|
|
kv->data.bo.bytes = (uint8_t*)malloc(v->data.bo.size);
|
|
|
|
memcpy(kv->data.bo.bytes, v->data.bo.bytes, v->data.bo.size);
|
|
|
|
kv->data.bo.size = (int)v->data.bo.size;
|
|
|
|
} else {
|
|
|
|
kv->data.bo.bytes = NULL;
|
|
|
|
kv->data.bo.size = 0;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case PMIX_PERSIST:
|
|
|
|
kv->type = OPAL_PERSIST;
|
2016-12-02 14:27:15 -08:00
|
|
|
kv->data.uint8 = pmix2x_convert_persist(v->data.persist);
|
2016-08-07 20:41:54 -07:00
|
|
|
break;
|
|
|
|
case PMIX_SCOPE:
|
|
|
|
kv->type = OPAL_SCOPE;
|
2016-12-02 14:27:15 -08:00
|
|
|
kv->data.uint8 = pmix2x_convert_scope(v->data.scope);
|
2016-08-07 20:41:54 -07:00
|
|
|
break;
|
|
|
|
case PMIX_DATA_RANGE:
|
|
|
|
kv->type = OPAL_DATA_RANGE;
|
2016-12-02 14:27:15 -08:00
|
|
|
kv->data.uint8 = pmix2x_convert_range(v->data.range);
|
2016-08-12 21:04:32 -07:00
|
|
|
break;
|
2016-08-07 20:41:54 -07:00
|
|
|
case PMIX_PROC_STATE:
|
|
|
|
kv->type = OPAL_PROC_STATE;
|
|
|
|
/* the OPAL layer doesn't have any concept of proc state,
|
|
|
|
* so the ORTE layer is responsible for converting it */
|
|
|
|
memcpy(&kv->data.uint8, &v->data.state, sizeof(uint8_t));
|
2016-08-12 21:04:32 -07:00
|
|
|
break;
|
|
|
|
case PMIX_POINTER:
|
|
|
|
kv->type = OPAL_PTR;
|
|
|
|
kv->data.ptr = v->data.ptr;
|
|
|
|
break;
|
2017-01-05 09:46:05 -08:00
|
|
|
case PMIX_DATA_ARRAY:
|
|
|
|
if (NULL == v->data.darray || NULL == v->data.darray->array) {
|
|
|
|
kv->data.ptr = NULL;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
lt = OBJ_NEW(opal_list_t);
|
|
|
|
kv->type = OPAL_PTR;
|
|
|
|
kv->data.ptr = (void*)lt;
|
|
|
|
for (n=0; n < v->data.darray->size; n++) {
|
|
|
|
ival = OBJ_NEW(opal_value_t);
|
|
|
|
opal_list_append(lt, &ival->super);
|
|
|
|
/* handle the various types */
|
|
|
|
if (PMIX_INFO == v->data.darray->type) {
|
|
|
|
pmix_info_t *iptr = (pmix_info_t*)v->data.darray->array;
|
|
|
|
ival->key = strdup(iptr[n].key);
|
|
|
|
pmix2x_value_unload(ival, &iptr[n].value);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
default:
|
2016-08-07 20:41:54 -07:00
|
|
|
/* silence warnings */
|
|
|
|
rc = OPAL_ERROR;
|
|
|
|
break;
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
2016-12-31 07:37:24 -08:00
|
|
|
static void errreg_cbfunc (pmix_status_t status,
|
|
|
|
size_t errhandler_ref,
|
|
|
|
void *cbdata)
|
|
|
|
{
|
|
|
|
pmix2x_opcaddy_t *op = (pmix2x_opcaddy_t*)cbdata;
|
|
|
|
|
|
|
|
op->event->index = errhandler_ref;
|
|
|
|
opal_output_verbose(5, opal_pmix_base_framework.framework_output,
|
|
|
|
"PMIX2x errreg_cbfunc - error handler registered status=%d, reference=%lu",
|
|
|
|
status, (unsigned long)errhandler_ref);
|
|
|
|
if (NULL != op->evregcbfunc) {
|
|
|
|
op->evregcbfunc(pmix2x_convert_rc(status), errhandler_ref, op->cbdata);
|
|
|
|
}
|
|
|
|
OBJ_RELEASE(op);
|
|
|
|
}
|
|
|
|
|
2016-06-01 16:34:03 -07:00
|
|
|
static void _reg_hdlr(int sd, short args, void *cbdata)
|
|
|
|
{
|
2016-12-02 14:27:15 -08:00
|
|
|
pmix2x_threadshift_t *cd = (pmix2x_threadshift_t*)cbdata;
|
2016-12-31 07:37:24 -08:00
|
|
|
pmix2x_opcaddy_t *op;
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_value_t *kv;
|
|
|
|
size_t n;
|
|
|
|
|
|
|
|
opal_output_verbose(2, opal_pmix_base_framework.framework_output,
|
2016-08-07 20:41:54 -07:00
|
|
|
"%s REGISTER HANDLER CODES %s",
|
|
|
|
OPAL_NAME_PRINT(OPAL_PROC_MY_NAME),
|
|
|
|
(NULL == cd->event_codes) ? "NULL" : "NON-NULL");
|
2016-06-01 16:34:03 -07:00
|
|
|
|
2016-12-31 07:37:24 -08:00
|
|
|
op = OBJ_NEW(pmix2x_opcaddy_t);
|
|
|
|
op->evregcbfunc = cd->cbfunc;
|
|
|
|
op->cbdata = cd->cbdata;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
2016-12-31 07:37:24 -08:00
|
|
|
/* convert the event codes */
|
|
|
|
if (NULL != cd->event_codes) {
|
|
|
|
op->ncodes = opal_list_get_size(cd->event_codes);
|
|
|
|
op->pcodes = (pmix_status_t*)malloc(op->ncodes * sizeof(pmix_status_t));
|
|
|
|
n=0;
|
2016-08-07 20:41:54 -07:00
|
|
|
OPAL_LIST_FOREACH(kv, cd->event_codes, opal_value_t) {
|
2016-12-31 07:37:24 -08:00
|
|
|
op->pcodes[n] = pmix2x_convert_opalrc(kv->data.integer);
|
2016-08-07 20:41:54 -07:00
|
|
|
}
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
|
2016-12-31 07:37:24 -08:00
|
|
|
/* convert the list of info to an array of pmix_info_t */
|
|
|
|
if (NULL != cd->info) {
|
|
|
|
op->ninfo = opal_list_get_size(cd->info);
|
|
|
|
if (0 < op->ninfo) {
|
|
|
|
PMIX_INFO_CREATE(op->info, op->ninfo);
|
|
|
|
n=0;
|
|
|
|
OPAL_LIST_FOREACH(kv, cd->info, opal_value_t) {
|
|
|
|
(void)strncpy(op->info[n].key, kv->key, PMIX_MAX_KEYLEN);
|
|
|
|
pmix2x_value_load(&op->info[n].value, kv);
|
|
|
|
++n;
|
2016-08-07 20:41:54 -07:00
|
|
|
}
|
|
|
|
}
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
|
2016-12-31 07:37:24 -08:00
|
|
|
/* register the event */
|
|
|
|
op->event = OBJ_NEW(opal_pmix2x_event_t);
|
|
|
|
op->event->handler = cd->evhandler;
|
|
|
|
opal_list_append(&mca_pmix_pmix2x_component.events, &op->event->super);
|
|
|
|
PMIx_Register_event_handler(op->pcodes, op->ncodes,
|
|
|
|
op->info, op->ninfo,
|
|
|
|
pmix2x_event_hdlr, errreg_cbfunc, op);
|
|
|
|
|
2016-06-01 16:34:03 -07:00
|
|
|
OBJ_RELEASE(cd);
|
|
|
|
return;
|
|
|
|
}
|
2016-12-31 07:37:24 -08:00
|
|
|
|
2016-06-01 16:34:03 -07:00
|
|
|
static void register_handler(opal_list_t *event_codes,
|
2016-08-07 20:41:54 -07:00
|
|
|
opal_list_t *info,
|
|
|
|
opal_pmix_notification_fn_t evhandler,
|
|
|
|
opal_pmix_evhandler_reg_cbfunc_t cbfunc,
|
|
|
|
void *cbdata)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
|
|
|
/* we must threadshift this request as we might not be in an event
|
|
|
|
* and we are going to access framework-global lists/objects */
|
|
|
|
|
|
|
|
OPAL_PMIX_THREADSHIFT(event_codes, info, evhandler, _reg_hdlr, cbfunc, cbdata);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void _dereg_hdlr(int sd, short args, void *cbdata)
|
|
|
|
{
|
2016-12-02 14:27:15 -08:00
|
|
|
pmix2x_threadshift_t *cd = (pmix2x_threadshift_t*)cbdata;
|
2016-12-31 07:37:24 -08:00
|
|
|
opal_pmix2x_event_t *event;
|
|
|
|
|
|
|
|
/* look for this event */
|
|
|
|
OPAL_LIST_FOREACH(event, &mca_pmix_pmix2x_component.events, opal_pmix2x_event_t) {
|
|
|
|
if (cd->handler == event->index) {
|
|
|
|
opal_list_remove_item(&mca_pmix_pmix2x_component.events, &event->super);
|
|
|
|
OBJ_RELEASE(event);
|
2016-08-07 20:41:54 -07:00
|
|
|
break;
|
|
|
|
}
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
2016-12-31 07:37:24 -08:00
|
|
|
/* tell the library to deregister this handler */
|
|
|
|
PMIx_Deregister_event_handler(cd->handler, NULL, NULL);
|
2016-06-01 16:34:03 -07:00
|
|
|
|
2016-12-31 07:37:24 -08:00
|
|
|
/* release the caller */
|
2016-06-01 16:34:03 -07:00
|
|
|
if (NULL != cd->opcbfunc) {
|
2016-08-07 20:41:54 -07:00
|
|
|
cd->opcbfunc(OPAL_SUCCESS, cd->cbdata);
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
OBJ_RELEASE(cd);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void deregister_handler(size_t evhandler,
|
2016-08-07 20:41:54 -07:00
|
|
|
opal_pmix_op_cbfunc_t cbfunc,
|
|
|
|
void *cbdata)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
|
|
|
/* we must threadshift this request as we might not be in an event
|
|
|
|
* and we are going to access framework-global lists/objects */
|
|
|
|
OPAL_PMIX_OP_THREADSHIFT(evhandler, _dereg_hdlr, cbfunc, cbdata);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2016-12-31 07:37:24 -08:00
|
|
|
static void notify_complete(pmix_status_t status, void *cbdata)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
2016-12-31 07:37:24 -08:00
|
|
|
pmix2x_opcaddy_t *op = (pmix2x_opcaddy_t*)cbdata;
|
|
|
|
if (NULL != op->opcbfunc) {
|
|
|
|
op->opcbfunc(pmix2x_convert_rc(status), op->cbdata);
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
2016-12-31 07:37:24 -08:00
|
|
|
OBJ_RELEASE(op);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void _notify(int sd, short args, void *cbdata)
|
|
|
|
{
|
|
|
|
pmix2x_threadshift_t *cd = (pmix2x_threadshift_t *)cbdata;
|
|
|
|
pmix2x_opcaddy_t *op;
|
|
|
|
opal_value_t *kv;
|
|
|
|
pmix_proc_t p, *pptr;
|
|
|
|
pmix_status_t pstatus;
|
|
|
|
size_t n;
|
|
|
|
int rc=OPAL_SUCCESS;
|
|
|
|
pmix_data_range_t prange;
|
|
|
|
opal_pmix2x_jobid_trkr_t *job, *jptr;
|
|
|
|
|
|
|
|
op = OBJ_NEW(pmix2x_opcaddy_t);
|
|
|
|
|
|
|
|
/* convert the status */
|
|
|
|
pstatus = pmix2x_convert_opalrc(cd->status);
|
|
|
|
|
|
|
|
/* convert the source */
|
|
|
|
if (NULL == cd->source) {
|
|
|
|
pptr = NULL;
|
|
|
|
} else {
|
|
|
|
/* look thru our list of jobids and find the
|
|
|
|
* corresponding nspace */
|
|
|
|
job = NULL;
|
|
|
|
OPAL_LIST_FOREACH(jptr, &mca_pmix_pmix2x_component.jobids, opal_pmix2x_jobid_trkr_t) {
|
|
|
|
if (jptr->jobid == cd->source->jobid) {
|
|
|
|
job = jptr;
|
|
|
|
break;
|
2016-08-07 20:41:54 -07:00
|
|
|
}
|
|
|
|
}
|
2016-12-31 07:37:24 -08:00
|
|
|
if (NULL == job) {
|
|
|
|
rc = OPAL_ERR_NOT_FOUND;
|
|
|
|
goto release;
|
|
|
|
}
|
|
|
|
(void)strncpy(p.nspace, job->nspace, PMIX_MAX_NSLEN);
|
|
|
|
p.rank = pmix2x_convert_opalrank(cd->source->vpid);
|
|
|
|
pptr = &p;
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
2016-12-31 07:37:24 -08:00
|
|
|
|
|
|
|
/* convert the range */
|
|
|
|
prange = pmix2x_convert_opalrange(cd->range);
|
|
|
|
|
|
|
|
/* convert the list of info */
|
|
|
|
if (NULL != cd->info) {
|
|
|
|
op->ninfo = opal_list_get_size(cd->info);
|
|
|
|
if (0 < op->ninfo) {
|
|
|
|
PMIX_INFO_CREATE(op->info, op->ninfo);
|
|
|
|
n=0;
|
|
|
|
OPAL_LIST_FOREACH(kv, cd->info, opal_value_t) {
|
|
|
|
(void)strncpy(op->info[n].key, kv->key, PMIX_MAX_KEYLEN);
|
|
|
|
pmix2x_value_load(&op->info[n].value, kv);
|
|
|
|
++n;
|
|
|
|
}
|
|
|
|
}
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
|
2016-12-31 07:37:24 -08:00
|
|
|
/* ask the library to notify our clients */
|
|
|
|
pstatus = PMIx_Notify_event(pstatus, pptr, prange, op->info, op->ninfo, notify_complete, op);
|
|
|
|
rc = pmix2x_convert_rc(pstatus);
|
|
|
|
|
|
|
|
release:
|
|
|
|
/* release the caller */
|
2016-06-01 16:34:03 -07:00
|
|
|
if (NULL != cd->opcbfunc) {
|
2016-12-31 07:37:24 -08:00
|
|
|
cd->opcbfunc(rc, cd->cbdata);
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
OBJ_RELEASE(cd);
|
|
|
|
}
|
|
|
|
|
|
|
|
static int notify_event(int status,
|
2016-08-07 20:41:54 -07:00
|
|
|
const opal_process_name_t *source,
|
|
|
|
opal_pmix_data_range_t range,
|
|
|
|
opal_list_t *info,
|
|
|
|
opal_pmix_op_cbfunc_t cbfunc, void *cbdata)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
|
|
|
/* we must threadshift this request as we might not be in an event
|
|
|
|
* and we are going to access framework-global lists/objects */
|
2016-12-31 07:37:24 -08:00
|
|
|
OPAL_PMIX_NOTIFY_THREADSHIFT(status, source, range, info, _notify, cbfunc, cbdata);
|
2016-06-01 16:34:03 -07:00
|
|
|
return OPAL_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2017-01-05 09:46:05 -08:00
|
|
|
static void relcbfunc(void *cbdata)
|
|
|
|
{
|
|
|
|
opal_list_t *results = (opal_list_t*)cbdata;
|
|
|
|
if (NULL != results) {
|
|
|
|
OPAL_LIST_RELEASE(results);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void infocbfunc(pmix_status_t status,
|
|
|
|
pmix_info_t *info, size_t ninfo,
|
|
|
|
void *cbdata,
|
|
|
|
pmix_release_cbfunc_t release_fn,
|
|
|
|
void *release_cbdata)
|
|
|
|
{
|
|
|
|
pmix2x_opcaddy_t *cd = (pmix2x_opcaddy_t*)cbdata;
|
|
|
|
int rc = OPAL_SUCCESS;
|
|
|
|
opal_list_t *results = NULL;
|
|
|
|
opal_value_t *iptr;
|
|
|
|
size_t n;
|
|
|
|
|
|
|
|
/* convert the array of pmix_info_t to the list of info */
|
|
|
|
if (NULL != info) {
|
|
|
|
results = OBJ_NEW(opal_list_t);
|
|
|
|
for (n=0; n < ninfo; n++) {
|
|
|
|
iptr = OBJ_NEW(opal_value_t);
|
|
|
|
opal_list_append(results, &iptr->super);
|
|
|
|
iptr->key = strdup(info[n].key);
|
|
|
|
if (OPAL_SUCCESS != (rc = pmix2x_value_unload(iptr, &info[n].value))) {
|
|
|
|
OPAL_LIST_RELEASE(results);
|
|
|
|
results = NULL;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (NULL != release_fn) {
|
|
|
|
release_fn(release_cbdata);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* return the values to the original requestor */
|
|
|
|
if (NULL != cd->qcbfunc) {
|
|
|
|
cd->qcbfunc(rc, results, cd->cbdata, relcbfunc, results);
|
|
|
|
}
|
|
|
|
OBJ_RELEASE(cd);
|
|
|
|
}
|
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
static void pmix2x_query(opal_list_t *queries,
|
2016-10-02 16:02:23 -07:00
|
|
|
opal_pmix_info_cbfunc_t cbfunc, void *cbdata)
|
|
|
|
{
|
2017-01-05 09:46:05 -08:00
|
|
|
int rc;
|
|
|
|
opal_value_t *ival;
|
|
|
|
size_t n, nqueries, nq;
|
|
|
|
pmix2x_opcaddy_t *cd;
|
|
|
|
pmix_status_t prc;
|
|
|
|
opal_pmix_query_t *q;
|
|
|
|
|
|
|
|
/* create the caddy */
|
|
|
|
cd = OBJ_NEW(pmix2x_opcaddy_t);
|
|
|
|
|
|
|
|
/* bozo check */
|
|
|
|
if (NULL == queries || 0 == (nqueries = opal_list_get_size(queries))) {
|
|
|
|
rc = OPAL_ERR_BAD_PARAM;
|
|
|
|
goto CLEANUP;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* setup the operation */
|
|
|
|
cd->qcbfunc = cbfunc;
|
|
|
|
cd->cbdata = cbdata;
|
|
|
|
cd->nqueries = nqueries;
|
|
|
|
|
|
|
|
/* convert the list to an array of query objects */
|
|
|
|
PMIX_QUERY_CREATE(cd->queries, cd->nqueries);
|
|
|
|
n=0;
|
|
|
|
OPAL_LIST_FOREACH(q, queries, opal_pmix_query_t) {
|
|
|
|
cd->queries[n].keys = opal_argv_copy(q->keys);
|
|
|
|
cd->queries[n].nqual = opal_list_get_size(&q->qualifiers);
|
|
|
|
if (0 < cd->queries[n].nqual) {
|
|
|
|
PMIX_INFO_CREATE(cd->queries[n].qualifiers, cd->queries[n].nqual);
|
|
|
|
nq = 0;
|
|
|
|
OPAL_LIST_FOREACH(ival, &q->qualifiers, opal_value_t) {
|
|
|
|
(void)strncpy(cd->queries[n].qualifiers[nq].key, ival->key, PMIX_MAX_KEYLEN);
|
|
|
|
pmix2x_value_load(&cd->queries[n].qualifiers[nq].value, ival);
|
|
|
|
++nq;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
++n;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* pass it down */
|
|
|
|
if (PMIX_SUCCESS != (prc = PMIx_Query_info_nb(cd->queries, cd->nqueries,
|
|
|
|
infocbfunc, cd))) {
|
|
|
|
/* do not hang! */
|
|
|
|
rc = pmix2x_convert_rc(prc);
|
|
|
|
goto CLEANUP;
|
|
|
|
}
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
CLEANUP:
|
2016-10-02 16:02:23 -07:00
|
|
|
if (NULL != cbfunc) {
|
2017-01-05 09:46:05 -08:00
|
|
|
cbfunc(rc, NULL, cbdata, NULL, NULL);
|
2016-10-02 16:02:23 -07:00
|
|
|
}
|
2017-01-05 09:46:05 -08:00
|
|
|
OBJ_RELEASE(cd);
|
2016-10-02 16:02:23 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void opcbfunc(pmix_status_t status, void *cbdata)
|
|
|
|
{
|
2016-12-02 14:27:15 -08:00
|
|
|
pmix2x_opcaddy_t *op = (pmix2x_opcaddy_t*)cbdata;
|
2016-10-02 16:02:23 -07:00
|
|
|
|
|
|
|
if (NULL != op->opcbfunc) {
|
2016-12-02 14:27:15 -08:00
|
|
|
op->opcbfunc(pmix2x_convert_rc(status), op->cbdata);
|
2016-10-02 16:02:23 -07:00
|
|
|
}
|
|
|
|
OBJ_RELEASE(op);
|
|
|
|
}
|
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
static void pmix2x_log(opal_list_t *info,
|
2016-10-02 16:02:23 -07:00
|
|
|
opal_pmix_op_cbfunc_t cbfunc, void *cbdata)
|
|
|
|
{
|
|
|
|
int rc;
|
|
|
|
opal_value_t *ival;
|
|
|
|
size_t n, ninfo;
|
2016-12-02 14:27:15 -08:00
|
|
|
pmix2x_opcaddy_t *cd;
|
2016-12-03 10:11:19 -08:00
|
|
|
pmix_status_t prc;
|
2016-10-02 16:02:23 -07:00
|
|
|
|
2016-12-03 21:19:32 -08:00
|
|
|
/* create the caddy */
|
2016-12-02 14:27:15 -08:00
|
|
|
cd = OBJ_NEW(pmix2x_opcaddy_t);
|
2016-10-02 16:02:23 -07:00
|
|
|
|
2016-12-03 10:11:19 -08:00
|
|
|
/* bozo check */
|
2016-12-03 21:19:32 -08:00
|
|
|
if (NULL == info || 0 == (ninfo = opal_list_get_size(info))) {
|
2016-12-03 10:11:19 -08:00
|
|
|
rc = OPAL_ERR_BAD_PARAM;
|
|
|
|
goto CLEANUP;
|
|
|
|
}
|
|
|
|
|
2016-12-03 21:19:32 -08:00
|
|
|
/* setup the operation */
|
|
|
|
cd->opcbfunc = cbfunc;
|
|
|
|
cd->cbdata = cbdata;
|
|
|
|
cd->ninfo = ninfo;
|
|
|
|
|
2016-10-02 16:02:23 -07:00
|
|
|
/* convert the list to an array of info objects */
|
|
|
|
PMIX_INFO_CREATE(cd->info, cd->ninfo);
|
|
|
|
n=0;
|
|
|
|
OPAL_LIST_FOREACH(ival, info, opal_value_t) {
|
|
|
|
(void)strncpy(cd->info[n].key, ival->key, PMIX_MAX_KEYLEN);
|
2016-12-02 14:27:15 -08:00
|
|
|
pmix2x_value_load(&cd->info[n].value, ival);
|
2016-10-02 16:02:23 -07:00
|
|
|
++n;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* pass it down */
|
2016-12-03 10:11:19 -08:00
|
|
|
if (PMIX_SUCCESS != (prc = PMIx_Log_nb(cd->info, cd->ninfo, NULL, 0,
|
|
|
|
opcbfunc, cd))) {
|
|
|
|
/* do not hang! */
|
|
|
|
rc = pmix2x_convert_rc(prc);
|
|
|
|
goto CLEANUP;
|
|
|
|
}
|
|
|
|
|
2016-10-02 16:02:23 -07:00
|
|
|
return;
|
|
|
|
|
|
|
|
CLEANUP:
|
|
|
|
if (NULL != cbfunc) {
|
|
|
|
cbfunc(rc, cbdata);
|
|
|
|
}
|
2016-12-03 10:11:19 -08:00
|
|
|
OBJ_RELEASE(cd);
|
2016-10-02 16:02:23 -07:00
|
|
|
}
|
|
|
|
|
2016-06-01 16:34:03 -07:00
|
|
|
/**** INSTANTIATE INTERNAL CLASSES ****/
|
2016-12-02 14:27:15 -08:00
|
|
|
OBJ_CLASS_INSTANCE(opal_pmix2x_jobid_trkr_t,
|
2016-08-07 20:41:54 -07:00
|
|
|
opal_list_item_t,
|
|
|
|
NULL, NULL);
|
2016-06-01 16:34:03 -07:00
|
|
|
|
2016-12-31 07:37:24 -08:00
|
|
|
static void evcon(opal_pmix2x_event_t *p)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
2016-12-31 07:37:24 -08:00
|
|
|
p->handler = NULL;
|
|
|
|
p->cbdata = NULL;
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
2016-12-31 07:37:24 -08:00
|
|
|
OBJ_CLASS_INSTANCE(opal_pmix2x_event_t,
|
2016-08-07 20:41:54 -07:00
|
|
|
opal_list_item_t,
|
2016-12-31 07:37:24 -08:00
|
|
|
evcon, NULL);
|
2016-06-01 16:34:03 -07:00
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
static void opcon(pmix2x_opcaddy_t *p)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
|
|
|
memset(&p->p, 0, sizeof(pmix_proc_t));
|
|
|
|
p->procs = NULL;
|
|
|
|
p->nprocs = 0;
|
|
|
|
p->error_procs = NULL;
|
|
|
|
p->nerror_procs = 0;
|
|
|
|
p->info = NULL;
|
|
|
|
p->ninfo = 0;
|
|
|
|
p->apps = NULL;
|
|
|
|
p->sz = 0;
|
|
|
|
p->active = false;
|
2016-12-31 07:37:24 -08:00
|
|
|
p->codes = NULL;
|
|
|
|
p->pcodes = NULL;
|
2017-01-05 09:46:05 -08:00
|
|
|
p->queries = NULL;
|
|
|
|
p->nqueries = 0;
|
2016-12-31 07:37:24 -08:00
|
|
|
p->event = NULL;
|
2016-06-01 16:34:03 -07:00
|
|
|
p->opcbfunc = NULL;
|
|
|
|
p->mdxcbfunc = NULL;
|
|
|
|
p->valcbfunc = NULL;
|
|
|
|
p->lkcbfunc = NULL;
|
|
|
|
p->spcbfunc = NULL;
|
2016-12-31 07:37:24 -08:00
|
|
|
p->evregcbfunc = NULL;
|
2016-06-01 16:34:03 -07:00
|
|
|
p->cbdata = NULL;
|
|
|
|
}
|
2016-12-02 14:27:15 -08:00
|
|
|
static void opdes(pmix2x_opcaddy_t *p)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
|
|
|
if (NULL != p->procs) {
|
2016-08-07 20:41:54 -07:00
|
|
|
PMIX_PROC_FREE(p->procs, p->nprocs);
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
if (NULL != p->error_procs) {
|
2016-08-07 20:41:54 -07:00
|
|
|
PMIX_PROC_FREE(p->error_procs, p->nerror_procs);
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
if (NULL != p->info) {
|
2016-08-07 20:41:54 -07:00
|
|
|
PMIX_INFO_FREE(p->info, p->sz);
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
|
|
|
if (NULL != p->apps) {
|
2016-08-07 20:41:54 -07:00
|
|
|
PMIX_APP_FREE(p->apps, p->sz);
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
2016-12-31 07:37:24 -08:00
|
|
|
if (NULL != p->pcodes) {
|
|
|
|
free(p->pcodes);
|
|
|
|
}
|
2017-01-05 09:46:05 -08:00
|
|
|
if (NULL != p->queries) {
|
|
|
|
PMIX_QUERY_FREE(p->queries, p->nqueries);
|
|
|
|
}
|
2016-06-01 16:34:03 -07:00
|
|
|
}
|
2016-12-02 14:27:15 -08:00
|
|
|
OBJ_CLASS_INSTANCE(pmix2x_opcaddy_t,
|
2016-08-07 20:41:54 -07:00
|
|
|
opal_object_t,
|
|
|
|
opcon, opdes);
|
2016-06-01 16:34:03 -07:00
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
static void ocadcon(pmix2x_opalcaddy_t *p)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
|
|
|
OBJ_CONSTRUCT(&p->procs, opal_list_t);
|
|
|
|
OBJ_CONSTRUCT(&p->info, opal_list_t);
|
|
|
|
OBJ_CONSTRUCT(&p->apps, opal_list_t);
|
|
|
|
p->opcbfunc = NULL;
|
|
|
|
p->dmdxfunc = NULL;
|
|
|
|
p->mdxcbfunc = NULL;
|
|
|
|
p->lkupcbfunc = NULL;
|
|
|
|
p->spwncbfunc = NULL;
|
|
|
|
p->cbdata = NULL;
|
|
|
|
p->odmdxfunc = NULL;
|
2016-06-17 15:15:13 -07:00
|
|
|
p->infocbfunc = NULL;
|
|
|
|
p->toolcbfunc = NULL;
|
2016-06-01 16:34:03 -07:00
|
|
|
p->ocbdata = NULL;
|
|
|
|
}
|
2016-12-02 14:27:15 -08:00
|
|
|
static void ocaddes(pmix2x_opalcaddy_t *p)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
|
|
|
OPAL_LIST_DESTRUCT(&p->procs);
|
|
|
|
OPAL_LIST_DESTRUCT(&p->info);
|
|
|
|
OPAL_LIST_DESTRUCT(&p->apps);
|
|
|
|
}
|
2016-12-02 14:27:15 -08:00
|
|
|
OBJ_CLASS_INSTANCE(pmix2x_opalcaddy_t,
|
2016-08-07 20:41:54 -07:00
|
|
|
opal_object_t,
|
|
|
|
ocadcon, ocaddes);
|
2016-06-01 16:34:03 -07:00
|
|
|
|
2016-12-02 14:27:15 -08:00
|
|
|
static void tscon(pmix2x_threadshift_t *p)
|
2016-06-01 16:34:03 -07:00
|
|
|
{
|
|
|
|
p->active = false;
|
|
|
|
p->source = NULL;
|
|
|
|
p->event_codes = NULL;
|
|
|
|
p->info = NULL;
|
2016-12-31 07:37:24 -08:00
|
|
|
OBJ_CONSTRUCT(&p->results, opal_list_t);
|
2016-06-01 16:34:03 -07:00
|
|
|
p->evhandler = NULL;
|
2016-07-16 13:20:41 -07:00
|
|
|
p->nondefault = false;
|
2016-06-01 16:34:03 -07:00
|
|
|
p->cbfunc = NULL;
|
|
|
|
p->opcbfunc = NULL;
|
|
|
|
p->cbdata = NULL;
|
|
|
|
}
|
2016-12-31 07:37:24 -08:00
|
|
|
static void tsdes(pmix2x_threadshift_t *p)
|
|
|
|
{
|
|
|
|
OPAL_LIST_DESTRUCT(&p->results);
|
|
|
|
}
|
2016-12-02 14:27:15 -08:00
|
|
|
OBJ_CLASS_INSTANCE(pmix2x_threadshift_t,
|
2016-08-07 20:41:54 -07:00
|
|
|
opal_object_t,
|
2016-12-31 07:37:24 -08:00
|
|
|
tscon, tsdes);
|