2016-06-01 16:34:03 -07:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2014-2016 Intel, Inc. All rights reserved.
|
|
|
|
* Copyright (c) 2014-2015 Mellanox Technologies, Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
* Copyright (c) 2016 Research Organization for Information Science
|
|
|
|
* and Technology (RIST). All rights reserved.
|
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef MCA_PMIX_PMIX2X_H
|
|
|
|
#define MCA_PMIX_PMIX2X_H
|
|
|
|
|
|
|
|
#include "opal_config.h"
|
|
|
|
|
|
|
|
#ifdef HAVE_SYS_SOCKET_H
|
|
|
|
#include <sys/socket.h>
|
|
|
|
#endif
|
|
|
|
#ifdef HAVE_SYS_UN_H
|
|
|
|
#include <sys/un.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "opal/class/opal_list.h"
|
|
|
|
#include "opal/mca/mca.h"
|
|
|
|
#include "opal/mca/event/event.h"
|
|
|
|
#include "opal/util/proc.h"
|
|
|
|
|
|
|
|
#include "opal/mca/pmix/pmix.h"
|
|
|
|
#include "pmix_server.h"
|
2016-08-10 21:03:00 -07:00
|
|
|
#include "pmix_common.h"
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
BEGIN_C_DECLS
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
opal_pmix_base_component_t super;
|
|
|
|
opal_list_t jobids;
|
|
|
|
bool native_launch;
|
|
|
|
size_t evindex;
|
|
|
|
opal_list_t single_events;
|
|
|
|
opal_list_t multi_events;
|
|
|
|
opal_list_t default_events;
|
|
|
|
int cache_size;
|
|
|
|
opal_list_t cache;
|
2016-08-25 08:05:03 -07:00
|
|
|
} mca_pmix_pmix3x_component_t;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_DECLSPEC extern mca_pmix_pmix3x_component_t mca_pmix_pmix3x_component;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_DECLSPEC extern const opal_pmix_base_module_t opal_pmix_pmix3x_module;
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
/**** INTERNAL OBJECTS ****/
|
|
|
|
typedef struct {
|
|
|
|
opal_list_item_t super;
|
|
|
|
opal_jobid_t jobid;
|
|
|
|
char nspace[PMIX_MAX_NSLEN + 1];
|
2016-08-25 08:05:03 -07:00
|
|
|
} opal_pmix3x_jobid_trkr_t;
|
|
|
|
OBJ_CLASS_DECLARATION(opal_pmix3x_jobid_trkr_t);
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
opal_list_item_t super;
|
|
|
|
size_t index;
|
|
|
|
int code;
|
|
|
|
opal_pmix_notification_fn_t handler;
|
2016-08-25 08:05:03 -07:00
|
|
|
} opal_pmix3x_single_event_t;
|
|
|
|
OBJ_CLASS_DECLARATION(opal_pmix3x_single_event_t);
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
opal_list_item_t super;
|
|
|
|
size_t index;
|
|
|
|
int *codes;
|
|
|
|
size_t ncodes;
|
|
|
|
opal_pmix_notification_fn_t handler;
|
2016-08-25 08:05:03 -07:00
|
|
|
} opal_pmix3x_multi_event_t;
|
|
|
|
OBJ_CLASS_DECLARATION(opal_pmix3x_multi_event_t);
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
opal_list_item_t super;
|
|
|
|
size_t index;
|
|
|
|
opal_pmix_notification_fn_t handler;
|
2016-08-25 08:05:03 -07:00
|
|
|
} opal_pmix3x_default_event_t;
|
|
|
|
OBJ_CLASS_DECLARATION(opal_pmix3x_default_event_t);
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
opal_list_item_t super;
|
|
|
|
int status;
|
|
|
|
bool nondefault;
|
|
|
|
opal_process_name_t source;
|
|
|
|
pmix_data_range_t range;
|
|
|
|
opal_list_t *info;
|
|
|
|
opal_list_t results;
|
2016-08-25 08:05:03 -07:00
|
|
|
opal_pmix3x_single_event_t *sing;
|
|
|
|
opal_pmix3x_multi_event_t *multi;
|
|
|
|
opal_pmix3x_default_event_t *def;
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_pmix_op_cbfunc_t final_cbfunc;
|
|
|
|
void *final_cbdata;
|
2016-08-25 08:05:03 -07:00
|
|
|
} opal_pmix3x_event_chain_t;
|
|
|
|
OBJ_CLASS_DECLARATION(opal_pmix3x_event_chain_t);
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
opal_object_t super;
|
|
|
|
pmix_status_t status;
|
|
|
|
pmix_proc_t p;
|
|
|
|
pmix_proc_t *procs;
|
|
|
|
size_t nprocs;
|
|
|
|
pmix_proc_t *error_procs;
|
|
|
|
size_t nerror_procs;
|
|
|
|
pmix_info_t *info;
|
|
|
|
size_t ninfo;
|
|
|
|
pmix_app_t *apps;
|
|
|
|
size_t sz;
|
|
|
|
volatile bool active;
|
|
|
|
opal_pmix_op_cbfunc_t opcbfunc;
|
|
|
|
opal_pmix_modex_cbfunc_t mdxcbfunc;
|
|
|
|
opal_pmix_value_cbfunc_t valcbfunc;
|
|
|
|
opal_pmix_lookup_cbfunc_t lkcbfunc;
|
|
|
|
opal_pmix_spawn_cbfunc_t spcbfunc;
|
|
|
|
void *cbdata;
|
2016-08-25 08:05:03 -07:00
|
|
|
} pmix3x_opcaddy_t;
|
|
|
|
OBJ_CLASS_DECLARATION(pmix3x_opcaddy_t);
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
opal_object_t super;
|
|
|
|
opal_list_t procs;
|
|
|
|
opal_list_t info;
|
|
|
|
opal_list_t apps;
|
|
|
|
pmix_op_cbfunc_t opcbfunc;
|
|
|
|
pmix_dmodex_response_fn_t dmdxfunc;
|
|
|
|
pmix_modex_cbfunc_t mdxcbfunc;
|
|
|
|
pmix_lookup_cbfunc_t lkupcbfunc;
|
|
|
|
pmix_spawn_cbfunc_t spwncbfunc;
|
2016-06-17 15:15:13 -07:00
|
|
|
pmix_info_cbfunc_t infocbfunc;
|
|
|
|
pmix_tool_connection_cbfunc_t toolcbfunc;
|
2016-06-01 16:34:03 -07:00
|
|
|
void *cbdata;
|
|
|
|
opal_pmix_release_cbfunc_t odmdxfunc;
|
|
|
|
void *ocbdata;
|
2016-08-25 08:05:03 -07:00
|
|
|
} pmix3x_opalcaddy_t;
|
|
|
|
OBJ_CLASS_DECLARATION(pmix3x_opalcaddy_t);
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
opal_object_t super;
|
|
|
|
opal_event_t ev;
|
|
|
|
volatile bool active;
|
|
|
|
size_t id;
|
|
|
|
int status;
|
|
|
|
opal_process_name_t pname;
|
|
|
|
opal_jobid_t jobid;
|
|
|
|
const opal_process_name_t *source;
|
|
|
|
opal_pmix_data_range_t range;
|
|
|
|
bool nondefault;
|
|
|
|
size_t handler;
|
|
|
|
opal_list_t *event_codes;
|
|
|
|
opal_list_t *info;
|
|
|
|
opal_pmix_notification_fn_t evhandler;
|
|
|
|
opal_pmix_evhandler_reg_cbfunc_t cbfunc;
|
|
|
|
opal_pmix_op_cbfunc_t opcbfunc;
|
|
|
|
void *cbdata;
|
2016-08-25 08:05:03 -07:00
|
|
|
} pmix3x_threadshift_t;
|
|
|
|
OBJ_CLASS_DECLARATION(pmix3x_threadshift_t);
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
#define OPAL_PMIX_OPCD_THREADSHIFT(i, s, sr, if, nif, fn, cb, cd) \
|
|
|
|
do { \
|
2016-08-25 08:05:03 -07:00
|
|
|
pmix3x_opalcaddy_t *_cd; \
|
|
|
|
_cd = OBJ_NEW(pmix3x_opalcaddy_t); \
|
2016-06-01 16:34:03 -07:00
|
|
|
_cd->id = (i); \
|
|
|
|
_cd->status = (s); \
|
|
|
|
_cd->source = (sr); \
|
|
|
|
_cd->info = (i); \
|
|
|
|
_cd->evcbfunc = (cb); \
|
|
|
|
_cd->cbdata = (cd); \
|
|
|
|
event_assign(&((_cd)->ev), opal_pmix_base.evbase, \
|
|
|
|
-1, EV_WRITE, (fn), (_cd)); \
|
|
|
|
event_active(&((_cd)->ev), EV_WRITE, 1); \
|
|
|
|
} while(0)
|
|
|
|
|
|
|
|
#define OPAL_PMIX_OP_THREADSHIFT(e, fn, cb, cd) \
|
|
|
|
do { \
|
2016-08-25 08:05:03 -07:00
|
|
|
pmix3x_threadshift_t *_cd; \
|
|
|
|
_cd = OBJ_NEW(pmix3x_threadshift_t); \
|
2016-06-01 16:34:03 -07:00
|
|
|
_cd->handler = (e); \
|
|
|
|
_cd->opcbfunc = (cb); \
|
|
|
|
_cd->cbdata = (cd); \
|
|
|
|
event_assign(&((_cd)->ev), opal_pmix_base.evbase, \
|
|
|
|
-1, EV_WRITE, (fn), (_cd)); \
|
|
|
|
event_active(&((_cd)->ev), EV_WRITE, 1); \
|
|
|
|
} while(0)
|
|
|
|
|
|
|
|
#define OPAL_PMIX_THREADSHIFT(e, i, eh, fn, cb, cd) \
|
|
|
|
do { \
|
2016-08-25 08:05:03 -07:00
|
|
|
pmix3x_threadshift_t *_cd; \
|
|
|
|
_cd = OBJ_NEW(pmix3x_threadshift_t); \
|
2016-06-01 16:34:03 -07:00
|
|
|
_cd->event_codes = (e); \
|
|
|
|
_cd->info = (i); \
|
|
|
|
_cd->evhandler = (eh); \
|
|
|
|
_cd->cbfunc = (cb); \
|
|
|
|
_cd->cbdata = (cd); \
|
|
|
|
event_assign(&((_cd)->ev), opal_pmix_base.evbase, \
|
|
|
|
-1, EV_WRITE, (fn), (_cd)); \
|
|
|
|
event_active(&((_cd)->ev), EV_WRITE, 1); \
|
|
|
|
} while(0)
|
|
|
|
|
|
|
|
#define OPAL_PMIX_NOTIFY_THREADSHIFT(s, sr, r, i, fn, cb, cd) \
|
|
|
|
do { \
|
2016-08-25 08:05:03 -07:00
|
|
|
pmix3x_threadshift_t *_cd; \
|
|
|
|
_cd = OBJ_NEW(pmix3x_threadshift_t); \
|
2016-06-01 16:34:03 -07:00
|
|
|
_cd->status = (s); \
|
|
|
|
_cd->source = (sr); \
|
|
|
|
_cd->range = (r); \
|
|
|
|
_cd->info = (i); \
|
|
|
|
_cd->opcbfunc = (cb); \
|
|
|
|
_cd->cbdata = (cd); \
|
|
|
|
event_assign(&((_cd)->ev), opal_pmix_base.evbase, \
|
|
|
|
-1, EV_WRITE, (fn), (_cd)); \
|
|
|
|
event_active(&((_cd)->ev), EV_WRITE, 1); \
|
|
|
|
} while(0)
|
|
|
|
|
|
|
|
/**** CLIENT FUNCTIONS ****/
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_client_init(void);
|
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_client_finalize(void);
|
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_initialized(void);
|
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_abort(int flag, const char *msg,
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_list_t *procs);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_commit(void);
|
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_fence(opal_list_t *procs, int collect_data);
|
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_fencenb(opal_list_t *procs, int collect_data,
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_pmix_op_cbfunc_t cbfunc, void *cbdata);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_put(opal_pmix_scope_t scope,
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_value_t *val);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_get(const opal_process_name_t *proc, const char *key,
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_list_t *info, opal_value_t **val);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_getnb(const opal_process_name_t *proc, const char *key,
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_list_t *info,
|
|
|
|
opal_pmix_value_cbfunc_t cbfunc, void *cbdata);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_publish(opal_list_t *info);
|
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_publishnb(opal_list_t *info,
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_pmix_op_cbfunc_t cbfunc, void *cbdata);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_lookup(opal_list_t *data, opal_list_t *info);
|
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_lookupnb(char **keys, opal_list_t *info,
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_pmix_lookup_cbfunc_t cbfunc, void *cbdata);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_unpublish(char **keys, opal_list_t *info);
|
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_unpublishnb(char **keys, opal_list_t *info,
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_pmix_op_cbfunc_t cbfunc, void *cbdata);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_spawn(opal_list_t *job_info, opal_list_t *apps, opal_jobid_t *jobid);
|
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_spawnnb(opal_list_t *job_info, opal_list_t *apps,
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_pmix_spawn_cbfunc_t cbfunc, void *cbdata);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_connect(opal_list_t *procs);
|
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_connectnb(opal_list_t *procs,
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_pmix_op_cbfunc_t cbfunc,
|
|
|
|
void *cbdata);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_disconnect(opal_list_t *procs);
|
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_disconnectnb(opal_list_t *procs,
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_pmix_op_cbfunc_t cbfunc,
|
|
|
|
void *cbdata);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_resolve_peers(const char *nodename, opal_jobid_t jobid,
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_list_t *procs);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_resolve_nodes(opal_jobid_t jobid, char **nodelist);
|
2016-06-01 16:34:03 -07:00
|
|
|
|
|
|
|
/**** COMMON FUNCTIONS ****/
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_store_local(const opal_process_name_t *proc,
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_value_t *val);
|
|
|
|
|
|
|
|
/**** SERVER SOUTHBOUND FUNCTIONS ****/
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_server_init(opal_pmix_server_module_t *module,
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_list_t *info);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_server_finalize(void);
|
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_server_gen_regex(const char *input, char **regex);
|
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_server_gen_ppn(const char *input, char **ppn);
|
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_server_register_nspace(opal_jobid_t jobid,
|
2016-06-01 16:34:03 -07:00
|
|
|
int nlocalprocs,
|
|
|
|
opal_list_t *info,
|
|
|
|
opal_pmix_op_cbfunc_t cbfunc,
|
|
|
|
void *cbdata);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC void pmix3x_server_deregister_nspace(opal_jobid_t jobid,
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_pmix_op_cbfunc_t cbfunc,
|
|
|
|
void *cbdata);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_server_register_client(const opal_process_name_t *proc,
|
2016-06-01 16:34:03 -07:00
|
|
|
uid_t uid, gid_t gid,
|
|
|
|
void *server_object,
|
|
|
|
opal_pmix_op_cbfunc_t cbfunc,
|
|
|
|
void *cbdata);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC void pmix3x_server_deregister_client(const opal_process_name_t *proc,
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_pmix_op_cbfunc_t cbfunc,
|
|
|
|
void *cbdata);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_server_setup_fork(const opal_process_name_t *proc, char ***env);
|
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_server_dmodex(const opal_process_name_t *proc,
|
2016-06-01 16:34:03 -07:00
|
|
|
opal_pmix_modex_cbfunc_t cbfunc, void *cbdata);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_server_notify_event(int status,
|
2016-06-01 16:34:03 -07:00
|
|
|
const opal_process_name_t *source,
|
|
|
|
opal_list_t *info,
|
|
|
|
opal_pmix_op_cbfunc_t cbfunc, void *cbdata);
|
|
|
|
|
|
|
|
|
|
|
|
/**** COMPONENT UTILITY FUNCTIONS ****/
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC void pmix3x_event_hdlr(size_t evhdlr_registration_id,
|
2016-06-01 16:34:03 -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-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC pmix_status_t pmix3x_convert_opalrc(int rc);
|
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_convert_rc(pmix_status_t rc);
|
2016-08-07 20:41:54 -07:00
|
|
|
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC opal_vpid_t pmix3x_convert_rank(int rank);
|
|
|
|
OPAL_MODULE_DECLSPEC pmix_rank_t pmix3x_convert_opalrank(opal_vpid_t vpid);
|
2016-08-07 20:41:54 -07:00
|
|
|
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC opal_pmix_scope_t pmix3x_convert_scope(pmix_scope_t scope);
|
|
|
|
OPAL_MODULE_DECLSPEC pmix_scope_t pmix3x_convert_opalscope(opal_pmix_scope_t scope);
|
2016-08-07 20:41:54 -07:00
|
|
|
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC pmix_data_range_t pmix3x_convert_opalrange(opal_pmix_data_range_t range);
|
|
|
|
OPAL_MODULE_DECLSPEC opal_pmix_data_range_t pmix3x_convert_range(pmix_data_range_t range);
|
2016-08-07 20:41:54 -07:00
|
|
|
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC opal_pmix_persistence_t pmix3x_convert_persist(pmix_persistence_t scope);
|
|
|
|
OPAL_MODULE_DECLSPEC pmix_persistence_t pmix3x_convert_opalpersist(opal_pmix_persistence_t scope);
|
2016-08-07 20:41:54 -07:00
|
|
|
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC void pmix3x_value_load(pmix_value_t *v,
|
2016-06-17 15:15:13 -07:00
|
|
|
opal_value_t *kv);
|
2016-08-25 08:05:03 -07:00
|
|
|
OPAL_MODULE_DECLSPEC int pmix3x_value_unload(opal_value_t *kv,
|
2016-06-01 16:34:03 -07:00
|
|
|
const pmix_value_t *v);
|
|
|
|
|
|
|
|
END_C_DECLS
|
|
|
|
|
|
|
|
#endif /* MCA_PMIX_EXTERNAL_H */
|