2004-08-15 07:33:13 +04:00
|
|
|
/*
|
2005-11-05 22:57:48 +03:00
|
|
|
* Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
|
|
|
|
* University Research and Technology
|
|
|
|
* Corporation. All rights reserved.
|
2006-08-23 07:32:36 +04:00
|
|
|
* Copyright (c) 2004-2006 The University of Tennessee and The University
|
2005-11-05 22:57:48 +03:00
|
|
|
* of Tennessee Research Foundation. All rights
|
|
|
|
* reserved.
|
2005-09-01 05:07:30 +04:00
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
2004-11-28 23:09:25 +03:00
|
|
|
* University of Stuttgart. All rights reserved.
|
2005-03-24 15:43:37 +03:00
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
2004-11-22 04:38:40 +03:00
|
|
|
* $COPYRIGHT$
|
2005-09-01 05:07:30 +04:00
|
|
|
*
|
2004-11-22 04:38:40 +03:00
|
|
|
* Additional copyrights may follow
|
2005-09-01 05:07:30 +04:00
|
|
|
*
|
2004-08-15 07:33:13 +04:00
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
2005-03-14 23:57:21 +03:00
|
|
|
#include "orte_config.h"
|
2005-12-01 21:28:20 +03:00
|
|
|
|
2006-02-12 04:33:29 +03:00
|
|
|
#include "orte/orte_constants.h"
|
2005-12-01 21:28:20 +03:00
|
|
|
|
2005-07-04 03:31:27 +04:00
|
|
|
#include "opal/util/output.h"
|
2005-09-19 19:29:14 +04:00
|
|
|
#include "opal/util/trace.h"
|
2004-08-15 07:33:13 +04:00
|
|
|
|
2006-02-07 06:32:36 +03:00
|
|
|
#include "orte/dss/dss.h"
|
2005-09-19 19:29:14 +04:00
|
|
|
#include "orte/mca/errmgr/errmgr.h"
|
2005-05-01 04:53:00 +04:00
|
|
|
|
2005-09-19 19:29:14 +04:00
|
|
|
#include "orte/mca/gpr/base/base.h"
|
2004-08-15 07:33:13 +04:00
|
|
|
|
|
|
|
|
2004-09-11 16:56:52 +04:00
|
|
|
|
2004-08-15 07:33:13 +04:00
|
|
|
/*
|
|
|
|
* The following file was created by configure. It contains extern
|
|
|
|
* statements and the definition of an array of pointers to each
|
|
|
|
* component's public mca_base_module_t struct.
|
|
|
|
*/
|
|
|
|
|
2005-07-04 22:24:58 +04:00
|
|
|
#include "orte/mca/gpr/base/static-components.h"
|
2004-08-15 07:33:13 +04:00
|
|
|
|
2005-07-18 22:49:00 +04:00
|
|
|
/* JMS: This is only INT_MAX until bug 1345 is fixed, because this
|
|
|
|
value is used to set an MAC parameter, which can [currently] only
|
|
|
|
take an int. */
|
|
|
|
#define ORTE_GPR_ARRAY_MAX_SIZE INT_MAX
|
|
|
|
#define ORTE_GPR_ARRAY_BLOCK_SIZE 512
|
|
|
|
|
|
|
|
|
|
|
|
|
2004-08-15 07:33:13 +04:00
|
|
|
/*
|
|
|
|
* globals
|
|
|
|
*/
|
|
|
|
|
2005-03-14 23:57:21 +03:00
|
|
|
/** KEYVAL **/
|
|
|
|
/* constructor - used to initialize state of keyval instance */
|
|
|
|
static void orte_gpr_keyval_construct(orte_gpr_keyval_t* keyval)
|
2004-08-15 07:33:13 +04:00
|
|
|
{
|
2005-03-14 23:57:21 +03:00
|
|
|
keyval->key = NULL;
|
2006-02-07 06:32:36 +03:00
|
|
|
keyval->value = NULL;
|
2004-08-15 07:33:13 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
/* destructor - used to free any resources held by instance */
|
2005-03-14 23:57:21 +03:00
|
|
|
static void orte_gpr_keyval_destructor(orte_gpr_keyval_t* keyval)
|
2004-08-15 07:33:13 +04:00
|
|
|
{
|
2005-09-01 05:07:30 +04:00
|
|
|
|
2006-02-07 06:32:36 +03:00
|
|
|
if (NULL != keyval->key) free(keyval->key);
|
|
|
|
if (NULL != keyval->value) OBJ_RELEASE(keyval->value);
|
2004-08-15 07:33:13 +04:00
|
|
|
}
|
|
|
|
|
2005-07-03 20:06:07 +04:00
|
|
|
/* define instance of opal_class_t */
|
2004-08-15 07:33:13 +04:00
|
|
|
OBJ_CLASS_INSTANCE(
|
2005-03-14 23:57:21 +03:00
|
|
|
orte_gpr_keyval_t, /* type name */
|
2006-10-17 20:06:17 +04:00
|
|
|
opal_list_item_t, /* parent "class" name */
|
2005-03-14 23:57:21 +03:00
|
|
|
orte_gpr_keyval_construct, /* constructor */
|
|
|
|
orte_gpr_keyval_destructor); /* destructor */
|
2004-08-17 19:04:56 +04:00
|
|
|
|
|
|
|
|
2005-03-14 23:57:21 +03:00
|
|
|
|
|
|
|
/** VALUE **/
|
|
|
|
/* constructor - used to initialize state of registry value instance */
|
|
|
|
static void orte_gpr_value_construct(orte_gpr_value_t* reg_val)
|
2004-11-20 22:12:43 +03:00
|
|
|
{
|
2005-03-14 23:57:21 +03:00
|
|
|
reg_val->addr_mode = 0;
|
|
|
|
reg_val->segment = NULL;
|
|
|
|
reg_val->cnt = 0;
|
|
|
|
reg_val->keyvals = NULL;
|
|
|
|
reg_val->num_tokens = 0;
|
2005-06-24 20:59:37 +04:00
|
|
|
reg_val->tokens = NULL;
|
2004-11-20 22:12:43 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/* destructor - used to free any resources held by instance */
|
2005-03-14 23:57:21 +03:00
|
|
|
static void orte_gpr_value_destructor(orte_gpr_value_t* reg_val)
|
2004-11-20 22:12:43 +03:00
|
|
|
{
|
2005-03-14 23:57:21 +03:00
|
|
|
char **tokens;
|
2006-08-15 23:54:10 +04:00
|
|
|
orte_std_cntr_t i;
|
2005-03-14 23:57:21 +03:00
|
|
|
|
|
|
|
if (NULL != reg_val->segment) free(reg_val->segment);
|
2005-09-01 05:07:30 +04:00
|
|
|
|
2005-03-14 23:57:21 +03:00
|
|
|
if (0 < reg_val->cnt && NULL != reg_val->keyvals) {
|
|
|
|
for (i=0; i < reg_val->cnt; i++) {
|
2005-03-19 02:58:36 +03:00
|
|
|
if (NULL != reg_val->keyvals[i])
|
2005-03-14 23:57:21 +03:00
|
|
|
OBJ_RELEASE(reg_val->keyvals[i]);
|
|
|
|
}
|
2005-09-01 05:07:30 +04:00
|
|
|
free(reg_val->keyvals);
|
2005-03-14 23:57:21 +03:00
|
|
|
}
|
2005-09-01 05:07:30 +04:00
|
|
|
|
2005-03-14 23:57:21 +03:00
|
|
|
if (0 < reg_val->num_tokens && NULL != reg_val->tokens) {
|
|
|
|
tokens = reg_val->tokens;
|
|
|
|
for (i=0; i < reg_val->num_tokens; i++) {
|
|
|
|
if(NULL != tokens[i])
|
|
|
|
free(tokens[i]);
|
|
|
|
}
|
|
|
|
free(tokens);
|
|
|
|
}
|
2004-11-20 22:12:43 +03:00
|
|
|
}
|
|
|
|
|
2005-07-03 20:06:07 +04:00
|
|
|
/* define instance of opal_class_t */
|
2004-11-20 22:12:43 +03:00
|
|
|
OBJ_CLASS_INSTANCE(
|
2005-09-01 05:07:30 +04:00
|
|
|
orte_gpr_value_t, /* type name */
|
|
|
|
opal_object_t, /* parent "class" name */
|
|
|
|
orte_gpr_value_construct, /* constructor */
|
|
|
|
orte_gpr_value_destructor); /* destructor */
|
2004-11-20 22:12:43 +03:00
|
|
|
|
|
|
|
|
2005-03-14 23:57:21 +03:00
|
|
|
/** NOTIFY DATA **/
|
|
|
|
/* constructor - used to initialize state of registry value instance */
|
|
|
|
static void orte_gpr_notify_data_construct(orte_gpr_notify_data_t* ptr)
|
2004-08-17 19:04:56 +04:00
|
|
|
{
|
2005-09-01 05:07:30 +04:00
|
|
|
ptr->target = NULL;
|
2005-06-24 20:59:37 +04:00
|
|
|
ptr->id = ORTE_GPR_SUBSCRIPTION_ID_MAX;
|
2005-07-18 22:49:00 +04:00
|
|
|
ptr->remove = false;
|
2005-03-14 23:57:21 +03:00
|
|
|
ptr->cnt = 0;
|
2006-10-20 06:25:50 +04:00
|
|
|
orte_pointer_array_init(&(ptr->values), (orte_std_cntr_t)orte_gpr_array_block_size,
|
|
|
|
(orte_std_cntr_t)orte_gpr_array_max_size,
|
|
|
|
(orte_std_cntr_t)orte_gpr_array_block_size);
|
2005-07-18 22:49:00 +04:00
|
|
|
|
2004-08-17 19:04:56 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
/* destructor - used to free any resources held by instance */
|
2005-03-14 23:57:21 +03:00
|
|
|
static void orte_gpr_notify_data_destructor(orte_gpr_notify_data_t* ptr)
|
2004-08-17 19:04:56 +04:00
|
|
|
{
|
2006-08-15 23:54:10 +04:00
|
|
|
orte_std_cntr_t i, j;
|
2005-07-18 22:49:00 +04:00
|
|
|
orte_gpr_value_t **values;
|
2005-03-14 23:57:21 +03:00
|
|
|
|
2005-09-01 05:07:30 +04:00
|
|
|
if (NULL != ptr->target) free(ptr->target);
|
|
|
|
|
2005-07-18 22:49:00 +04:00
|
|
|
if (NULL != ptr->values) {
|
|
|
|
values = (orte_gpr_value_t**)(ptr->values)->addr;
|
|
|
|
for (i=0, j=0; j < ptr->cnt &&
|
|
|
|
i < (ptr->values)->size; i++) {
|
|
|
|
if (NULL != values[i]) {
|
|
|
|
j++;
|
|
|
|
OBJ_RELEASE(values[i]);
|
|
|
|
}
|
2005-03-14 23:57:21 +03:00
|
|
|
}
|
2005-07-18 22:49:00 +04:00
|
|
|
OBJ_RELEASE(ptr->values);
|
2004-08-17 19:04:56 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-07-03 20:06:07 +04:00
|
|
|
/* define instance of opal_class_t */
|
2004-08-17 19:04:56 +04:00
|
|
|
OBJ_CLASS_INSTANCE(
|
2005-03-14 23:57:21 +03:00
|
|
|
orte_gpr_notify_data_t, /* type name */
|
2005-07-03 20:06:07 +04:00
|
|
|
opal_object_t, /* parent "class" name */
|
2005-03-14 23:57:21 +03:00
|
|
|
orte_gpr_notify_data_construct, /* constructor */
|
|
|
|
orte_gpr_notify_data_destructor); /* destructor */
|
2004-08-17 19:04:56 +04:00
|
|
|
|
|
|
|
|
2005-03-14 23:57:21 +03:00
|
|
|
/** SUBSCRIPTION **/
|
|
|
|
/* constructor - used to initialize state of registry subscription instance */
|
|
|
|
static void orte_gpr_subscription_construct(orte_gpr_subscription_t* sub)
|
2004-08-17 19:04:56 +04:00
|
|
|
{
|
2005-06-24 20:59:37 +04:00
|
|
|
sub->name = NULL;
|
|
|
|
sub->id = ORTE_GPR_SUBSCRIPTION_ID_MAX;
|
|
|
|
sub->action = 0;
|
|
|
|
sub->cnt = 0;
|
|
|
|
sub->values = NULL;
|
2005-03-14 23:57:21 +03:00
|
|
|
sub->cbfunc = NULL;
|
|
|
|
sub->user_tag = NULL;
|
2004-08-17 19:04:56 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
/* destructor - used to free any resources held by instance */
|
2005-03-14 23:57:21 +03:00
|
|
|
static void orte_gpr_subscription_destructor(orte_gpr_subscription_t* sub)
|
2004-08-17 19:04:56 +04:00
|
|
|
{
|
2006-08-15 23:54:10 +04:00
|
|
|
orte_std_cntr_t i;
|
2005-03-14 23:57:21 +03:00
|
|
|
|
2005-06-24 20:59:37 +04:00
|
|
|
if (NULL != sub->name) free(sub->name);
|
2005-09-01 05:07:30 +04:00
|
|
|
|
2005-06-24 20:59:37 +04:00
|
|
|
if (0 < sub->cnt && NULL != sub->values) {
|
|
|
|
for (i=0; i < sub->cnt; i++) {
|
|
|
|
OBJ_RELEASE(sub->values[i]);
|
2005-03-14 23:57:21 +03:00
|
|
|
}
|
2005-06-24 20:59:37 +04:00
|
|
|
free(sub->values);
|
2004-08-17 19:04:56 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-07-03 20:06:07 +04:00
|
|
|
/* define instance of opal_class_t */
|
2004-08-17 19:04:56 +04:00
|
|
|
OBJ_CLASS_INSTANCE(
|
2005-03-14 23:57:21 +03:00
|
|
|
orte_gpr_subscription_t, /* type name */
|
2005-07-03 20:06:07 +04:00
|
|
|
opal_object_t, /* parent "class" name */
|
2005-03-14 23:57:21 +03:00
|
|
|
orte_gpr_subscription_construct, /* constructor */
|
|
|
|
orte_gpr_subscription_destructor); /* destructor */
|
2004-08-15 07:33:13 +04:00
|
|
|
|
|
|
|
|
2005-06-24 20:59:37 +04:00
|
|
|
/** TRIGGER **/
|
|
|
|
/* constructor - used to initialize state of registry subscription instance */
|
|
|
|
static void orte_gpr_trigger_construct(orte_gpr_trigger_t* trig)
|
|
|
|
{
|
|
|
|
trig->name = NULL;
|
|
|
|
trig->id = ORTE_GPR_TRIGGER_ID_MAX;
|
|
|
|
trig->action = 0;
|
|
|
|
trig->cnt = 0;
|
|
|
|
trig->values = NULL;
|
2005-07-18 22:49:00 +04:00
|
|
|
trig->cbfunc = NULL;
|
|
|
|
trig->user_tag = NULL;
|
2005-06-24 20:59:37 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
/* destructor - used to free any resources held by instance */
|
|
|
|
static void orte_gpr_trigger_destructor(orte_gpr_trigger_t* trig)
|
|
|
|
{
|
2006-08-15 23:54:10 +04:00
|
|
|
orte_std_cntr_t i;
|
2005-06-24 20:59:37 +04:00
|
|
|
|
|
|
|
if (NULL != trig->name) free(trig->name);
|
|
|
|
|
|
|
|
if (0 < trig->cnt && NULL != trig->values) {
|
|
|
|
for (i=0; i < trig->cnt; i++) OBJ_RELEASE(trig->values[i]);
|
|
|
|
free(trig->values);
|
|
|
|
}
|
2005-09-01 05:07:30 +04:00
|
|
|
|
2005-06-24 20:59:37 +04:00
|
|
|
}
|
|
|
|
|
2005-07-03 20:06:07 +04:00
|
|
|
/* define instance of opal_class_t */
|
2005-06-24 20:59:37 +04:00
|
|
|
OBJ_CLASS_INSTANCE(
|
|
|
|
orte_gpr_trigger_t, /* type name */
|
2005-07-03 20:06:07 +04:00
|
|
|
opal_object_t, /* parent "class" name */
|
2005-06-24 20:59:37 +04:00
|
|
|
orte_gpr_trigger_construct, /* constructor */
|
|
|
|
orte_gpr_trigger_destructor); /* destructor */
|
|
|
|
|
|
|
|
|
2005-03-14 23:57:21 +03:00
|
|
|
/** NOTIFY MESSAGE */
|
|
|
|
/* constructor - used to initialize notify message instance */
|
|
|
|
static void orte_gpr_notify_message_construct(orte_gpr_notify_message_t* msg)
|
2004-08-27 09:23:04 +04:00
|
|
|
{
|
2005-09-01 05:07:30 +04:00
|
|
|
msg->msg_type = 0;
|
|
|
|
msg->target = NULL;
|
2005-07-18 22:49:00 +04:00
|
|
|
msg->id = ORTE_GPR_TRIGGER_ID_MAX;
|
|
|
|
msg->remove = false;
|
2005-03-14 23:57:21 +03:00
|
|
|
msg->cnt = 0;
|
2006-10-20 06:25:50 +04:00
|
|
|
orte_pointer_array_init(&(msg->data), (orte_std_cntr_t)orte_gpr_array_block_size,
|
|
|
|
(orte_std_cntr_t)orte_gpr_array_max_size,
|
|
|
|
(orte_std_cntr_t)orte_gpr_array_block_size);
|
2004-08-27 09:23:04 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
/* destructor - used to free any resources held by instance */
|
2005-03-14 23:57:21 +03:00
|
|
|
static void orte_gpr_notify_message_destructor(orte_gpr_notify_message_t* msg)
|
2004-08-27 09:23:04 +04:00
|
|
|
{
|
2006-08-15 23:54:10 +04:00
|
|
|
orte_std_cntr_t i, j;
|
2005-07-18 22:49:00 +04:00
|
|
|
orte_gpr_notify_data_t **data;
|
2005-09-01 05:07:30 +04:00
|
|
|
|
|
|
|
if (NULL != msg->target) free(msg->target);
|
|
|
|
|
2005-07-18 22:49:00 +04:00
|
|
|
if (NULL != msg->data) {
|
|
|
|
data = (orte_gpr_notify_data_t**)(msg->data)->addr;
|
|
|
|
for (i=0, j=0; j < msg->cnt &&
|
|
|
|
i < (msg->data)->size; i++) {
|
|
|
|
if (NULL != data[i]) {
|
|
|
|
j++;
|
|
|
|
OBJ_RELEASE(data[i]);
|
|
|
|
}
|
2005-03-14 23:57:21 +03:00
|
|
|
}
|
2005-07-18 22:49:00 +04:00
|
|
|
OBJ_RELEASE(msg->data);
|
2005-03-14 23:57:21 +03:00
|
|
|
}
|
2005-09-01 05:07:30 +04:00
|
|
|
|
2004-08-27 09:23:04 +04:00
|
|
|
}
|
|
|
|
|
2005-07-03 20:06:07 +04:00
|
|
|
/* define instance of opal_class_t */
|
2004-08-27 09:23:04 +04:00
|
|
|
OBJ_CLASS_INSTANCE(
|
2005-03-14 23:57:21 +03:00
|
|
|
orte_gpr_notify_message_t, /* type name */
|
2005-07-03 20:06:07 +04:00
|
|
|
opal_object_t, /* parent "class" name */
|
2005-03-14 23:57:21 +03:00
|
|
|
orte_gpr_notify_message_construct, /* constructor */
|
|
|
|
orte_gpr_notify_message_destructor); /* destructor */
|
2004-08-27 09:23:04 +04:00
|
|
|
|
|
|
|
|
2004-08-15 07:33:13 +04:00
|
|
|
/*
|
|
|
|
* Global variables
|
|
|
|
*/
|
2005-03-14 23:57:21 +03:00
|
|
|
int orte_gpr_base_output = -1;
|
2005-07-18 22:49:00 +04:00
|
|
|
size_t orte_gpr_array_max_size, orte_gpr_array_block_size;
|
2005-03-14 23:57:21 +03:00
|
|
|
orte_gpr_base_module_t orte_gpr;
|
|
|
|
bool orte_gpr_base_selected = false;
|
2005-07-03 20:22:16 +04:00
|
|
|
opal_list_t orte_gpr_base_components_available;
|
2005-03-14 23:57:21 +03:00
|
|
|
mca_gpr_base_component_t orte_gpr_base_selected_component;
|
2005-07-04 02:45:48 +04:00
|
|
|
opal_mutex_t orte_gpr_mutex;
|
2004-08-15 07:33:13 +04:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function for finding and opening either all MCA components, or the one
|
|
|
|
* that was specifically requested via a MCA parameter.
|
|
|
|
*/
|
2005-03-14 23:57:21 +03:00
|
|
|
int orte_gpr_base_open(void)
|
2004-08-15 07:33:13 +04:00
|
|
|
{
|
2005-07-18 22:49:00 +04:00
|
|
|
int param, value, rc, id;
|
2005-05-01 04:58:06 +04:00
|
|
|
orte_data_type_t tmp;
|
2006-04-04 15:05:52 +04:00
|
|
|
opal_output_stream_t kill_prefix;
|
2004-11-20 22:12:43 +03:00
|
|
|
|
2005-09-19 19:29:14 +04:00
|
|
|
OPAL_TRACE(5);
|
2006-02-07 06:32:36 +03:00
|
|
|
|
2005-03-24 23:23:15 +03:00
|
|
|
/* Debugging / verbose output */
|
2006-04-04 15:05:52 +04:00
|
|
|
/** setup the structure to kill the blasted prefix that opal_output
|
|
|
|
* now defaults to including so the output can be legible again!
|
|
|
|
*/
|
|
|
|
OBJ_CONSTRUCT(&kill_prefix, opal_output_stream_t);
|
|
|
|
kill_prefix.lds_want_stderr = true;
|
|
|
|
kill_prefix.lds_prefix = NULL;
|
|
|
|
|
2005-08-15 22:25:35 +04:00
|
|
|
param = mca_base_param_reg_int_name("gpr_base", "verbose",
|
|
|
|
"Verbosity level for the gpr framework",
|
|
|
|
false, false, 0, &value);
|
2005-03-24 23:23:15 +03:00
|
|
|
if (value != 0) {
|
2006-04-04 15:05:52 +04:00
|
|
|
kill_prefix.lds_verbose_level = value;
|
2005-03-24 23:23:15 +03:00
|
|
|
}
|
2006-04-04 15:05:52 +04:00
|
|
|
orte_gpr_base_output = opal_output_open(&kill_prefix);
|
2006-08-23 07:32:36 +04:00
|
|
|
OBJ_DESTRUCT(&kill_prefix);
|
|
|
|
|
2005-07-18 22:49:00 +04:00
|
|
|
id = mca_base_param_register_int("gpr", "base", "maxsize", NULL,
|
|
|
|
ORTE_GPR_ARRAY_MAX_SIZE);
|
|
|
|
mca_base_param_lookup_int(id, ¶m);
|
|
|
|
orte_gpr_array_max_size = (size_t)param;
|
2005-09-01 05:07:30 +04:00
|
|
|
|
2005-07-18 22:49:00 +04:00
|
|
|
id = mca_base_param_register_int("gpr", "base", "blocksize", NULL,
|
|
|
|
ORTE_GPR_ARRAY_BLOCK_SIZE);
|
|
|
|
mca_base_param_lookup_int(id, ¶m);
|
|
|
|
orte_gpr_array_block_size = (size_t)param;
|
2005-09-01 05:07:30 +04:00
|
|
|
|
2005-05-01 04:58:06 +04:00
|
|
|
/* register the base data types with the DPS */
|
|
|
|
tmp = ORTE_GPR_CMD;
|
2006-02-07 06:32:36 +03:00
|
|
|
if (ORTE_SUCCESS != (rc = orte_dss.register_type(orte_gpr_base_pack_cmd,
|
2005-05-01 04:58:06 +04:00
|
|
|
orte_gpr_base_unpack_cmd,
|
2006-02-07 06:32:36 +03:00
|
|
|
(orte_dss_copy_fn_t)orte_gpr_base_copy_cmd,
|
|
|
|
(orte_dss_compare_fn_t)orte_gpr_base_compare_cmd,
|
|
|
|
(orte_dss_size_fn_t)orte_gpr_base_std_size,
|
|
|
|
(orte_dss_print_fn_t)orte_gpr_base_std_print,
|
|
|
|
(orte_dss_release_fn_t)orte_gpr_base_std_release,
|
|
|
|
ORTE_DSS_UNSTRUCTURED,
|
2005-05-01 04:58:06 +04:00
|
|
|
"ORTE_GPR_CMD", &tmp))) {
|
|
|
|
ORTE_ERROR_LOG(rc);
|
|
|
|
return rc;
|
|
|
|
}
|
2005-09-01 05:07:30 +04:00
|
|
|
|
2005-06-24 20:59:37 +04:00
|
|
|
tmp = ORTE_GPR_SUBSCRIPTION_ID;
|
2006-02-07 06:32:36 +03:00
|
|
|
if (ORTE_SUCCESS != (rc = orte_dss.register_type(orte_gpr_base_pack_subscription_id,
|
2005-06-24 20:59:37 +04:00
|
|
|
orte_gpr_base_unpack_subscription_id,
|
2006-02-07 06:32:36 +03:00
|
|
|
(orte_dss_copy_fn_t)orte_gpr_base_copy_subscription_id,
|
|
|
|
(orte_dss_compare_fn_t)orte_gpr_base_compare_subscription_id,
|
|
|
|
(orte_dss_size_fn_t)orte_gpr_base_std_size,
|
|
|
|
(orte_dss_print_fn_t)orte_gpr_base_std_print,
|
|
|
|
(orte_dss_release_fn_t)orte_gpr_base_std_release,
|
|
|
|
ORTE_DSS_UNSTRUCTURED,
|
2005-06-24 20:59:37 +04:00
|
|
|
"ORTE_GPR_SUBSCRIPTION_ID", &tmp))) {
|
|
|
|
ORTE_ERROR_LOG(rc);
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
|
|
|
tmp = ORTE_GPR_TRIGGER_ID;
|
2006-02-07 06:32:36 +03:00
|
|
|
if (ORTE_SUCCESS != (rc = orte_dss.register_type(orte_gpr_base_pack_trigger_id,
|
2005-06-24 20:59:37 +04:00
|
|
|
orte_gpr_base_unpack_trigger_id,
|
2006-02-07 06:32:36 +03:00
|
|
|
(orte_dss_copy_fn_t)orte_gpr_base_copy_trigger_id,
|
|
|
|
(orte_dss_compare_fn_t)orte_gpr_base_compare_trigger_id,
|
|
|
|
(orte_dss_size_fn_t)orte_gpr_base_std_size,
|
|
|
|
(orte_dss_print_fn_t)orte_gpr_base_std_print,
|
|
|
|
(orte_dss_release_fn_t)orte_gpr_base_std_release,
|
|
|
|
ORTE_DSS_UNSTRUCTURED,
|
2005-06-24 20:59:37 +04:00
|
|
|
"ORTE_GPR_TRIGGER_ID", &tmp))) {
|
2005-05-01 04:58:06 +04:00
|
|
|
ORTE_ERROR_LOG(rc);
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
2005-06-24 20:59:37 +04:00
|
|
|
tmp = ORTE_GPR_NOTIFY_ACTION;
|
2006-02-07 06:32:36 +03:00
|
|
|
if (ORTE_SUCCESS != (rc = orte_dss.register_type(orte_gpr_base_pack_notify_action,
|
2005-05-01 04:58:06 +04:00
|
|
|
orte_gpr_base_unpack_notify_action,
|
2006-02-07 06:32:36 +03:00
|
|
|
(orte_dss_copy_fn_t)orte_gpr_base_copy_notify_action,
|
|
|
|
(orte_dss_compare_fn_t)orte_gpr_base_compare_notify_action,
|
|
|
|
(orte_dss_size_fn_t)orte_gpr_base_std_size,
|
|
|
|
(orte_dss_print_fn_t)orte_gpr_base_std_print,
|
|
|
|
(orte_dss_release_fn_t)orte_gpr_base_std_release,
|
|
|
|
ORTE_DSS_UNSTRUCTURED,
|
2005-06-24 20:59:37 +04:00
|
|
|
"ORTE_GPR_NOTIFY_ACTION", &tmp))) {
|
|
|
|
ORTE_ERROR_LOG(rc);
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
|
|
|
tmp = ORTE_GPR_TRIGGER_ACTION;
|
2006-02-07 06:32:36 +03:00
|
|
|
if (ORTE_SUCCESS != (rc = orte_dss.register_type(orte_gpr_base_pack_trigger_action,
|
2005-06-24 20:59:37 +04:00
|
|
|
orte_gpr_base_unpack_trigger_action,
|
2006-02-07 06:32:36 +03:00
|
|
|
(orte_dss_copy_fn_t)orte_gpr_base_copy_trigger_action,
|
|
|
|
(orte_dss_compare_fn_t)orte_gpr_base_compare_trigger_action,
|
|
|
|
(orte_dss_size_fn_t)orte_gpr_base_std_size,
|
|
|
|
(orte_dss_print_fn_t)orte_gpr_base_std_print,
|
|
|
|
(orte_dss_release_fn_t)orte_gpr_base_std_release,
|
|
|
|
ORTE_DSS_UNSTRUCTURED,
|
2005-06-24 20:59:37 +04:00
|
|
|
"ORTE_GPR_TRIGGER_ACTION", &tmp))) {
|
2005-05-01 04:58:06 +04:00
|
|
|
ORTE_ERROR_LOG(rc);
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
2005-09-01 05:07:30 +04:00
|
|
|
tmp = ORTE_GPR_NOTIFY_MSG_TYPE;
|
2006-02-07 06:32:36 +03:00
|
|
|
if (ORTE_SUCCESS != (rc = orte_dss.register_type(orte_gpr_base_pack_notify_msg_type,
|
2005-09-01 05:07:30 +04:00
|
|
|
orte_gpr_base_unpack_notify_msg_type,
|
2006-02-07 06:32:36 +03:00
|
|
|
(orte_dss_copy_fn_t)orte_gpr_base_copy_notify_msg_type,
|
|
|
|
(orte_dss_compare_fn_t)orte_gpr_base_compare_notify_msg_type,
|
|
|
|
(orte_dss_size_fn_t)orte_gpr_base_std_size,
|
|
|
|
(orte_dss_print_fn_t)orte_gpr_base_std_print,
|
|
|
|
(orte_dss_release_fn_t)orte_gpr_base_std_release,
|
|
|
|
ORTE_DSS_UNSTRUCTURED,
|
2005-09-01 05:07:30 +04:00
|
|
|
"ORTE_GPR_NOTIFY_MSG_TYPE", &tmp))) {
|
|
|
|
ORTE_ERROR_LOG(rc);
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
2005-05-01 04:58:06 +04:00
|
|
|
tmp = ORTE_GPR_ADDR_MODE;
|
2006-02-07 06:32:36 +03:00
|
|
|
if (ORTE_SUCCESS != (rc = orte_dss.register_type(orte_gpr_base_pack_addr_mode,
|
2005-05-01 04:58:06 +04:00
|
|
|
orte_gpr_base_unpack_addr_mode,
|
2006-02-07 06:32:36 +03:00
|
|
|
(orte_dss_copy_fn_t)orte_gpr_base_copy_addr_mode,
|
|
|
|
(orte_dss_compare_fn_t)orte_gpr_base_compare_addr_mode,
|
|
|
|
(orte_dss_size_fn_t)orte_gpr_base_std_size,
|
|
|
|
(orte_dss_print_fn_t)orte_gpr_base_std_print,
|
|
|
|
(orte_dss_release_fn_t)orte_gpr_base_std_release,
|
|
|
|
ORTE_DSS_UNSTRUCTURED,
|
2005-05-01 04:58:06 +04:00
|
|
|
"ORTE_GPR_ADDR_MODE", &tmp))) {
|
|
|
|
ORTE_ERROR_LOG(rc);
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
2006-02-07 06:32:36 +03:00
|
|
|
tmp = ORTE_GPR_KEYVAL;
|
|
|
|
if (ORTE_SUCCESS != (rc = orte_dss.register_type(orte_gpr_base_pack_keyval,
|
2005-05-01 04:58:06 +04:00
|
|
|
orte_gpr_base_unpack_keyval,
|
2006-02-07 06:32:36 +03:00
|
|
|
(orte_dss_copy_fn_t)orte_gpr_base_copy_keyval,
|
|
|
|
(orte_dss_compare_fn_t)orte_gpr_base_compare_keyval,
|
|
|
|
(orte_dss_size_fn_t)orte_gpr_base_size_keyval,
|
|
|
|
(orte_dss_print_fn_t)orte_gpr_base_print_keyval,
|
|
|
|
(orte_dss_release_fn_t)orte_gpr_base_std_obj_release,
|
|
|
|
ORTE_DSS_STRUCTURED,
|
|
|
|
"ORTE_GPR_KEYVAL", &tmp))) {
|
2005-05-01 04:58:06 +04:00
|
|
|
ORTE_ERROR_LOG(rc);
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
|
|
|
tmp = ORTE_GPR_VALUE;
|
2006-02-07 06:32:36 +03:00
|
|
|
if (ORTE_SUCCESS != (rc = orte_dss.register_type(orte_gpr_base_pack_value,
|
2005-05-01 04:58:06 +04:00
|
|
|
orte_gpr_base_unpack_value,
|
2006-02-07 06:32:36 +03:00
|
|
|
(orte_dss_copy_fn_t)orte_gpr_base_copy_gpr_value,
|
|
|
|
(orte_dss_compare_fn_t)orte_gpr_base_compare_gpr_value,
|
|
|
|
(orte_dss_size_fn_t)orte_gpr_base_size_gpr_value,
|
|
|
|
(orte_dss_print_fn_t)orte_gpr_base_print_gpr_value,
|
|
|
|
(orte_dss_release_fn_t)orte_gpr_base_std_obj_release,
|
|
|
|
ORTE_DSS_STRUCTURED,
|
2005-05-01 04:58:06 +04:00
|
|
|
"ORTE_GPR_VALUE", &tmp))) {
|
|
|
|
ORTE_ERROR_LOG(rc);
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
|
|
|
tmp = ORTE_GPR_SUBSCRIPTION;
|
2006-02-07 06:32:36 +03:00
|
|
|
if (ORTE_SUCCESS != (rc = orte_dss.register_type(orte_gpr_base_pack_subscription,
|
2005-05-01 04:58:06 +04:00
|
|
|
orte_gpr_base_unpack_subscription,
|
2006-02-07 06:32:36 +03:00
|
|
|
(orte_dss_copy_fn_t)orte_gpr_base_copy_subscription,
|
|
|
|
(orte_dss_compare_fn_t)orte_gpr_base_compare_subscription,
|
|
|
|
(orte_dss_size_fn_t)orte_gpr_base_size_subscription,
|
|
|
|
(orte_dss_print_fn_t)orte_gpr_base_print_subscription,
|
|
|
|
(orte_dss_release_fn_t)orte_gpr_base_std_obj_release,
|
|
|
|
ORTE_DSS_STRUCTURED,
|
2005-05-01 04:58:06 +04:00
|
|
|
"ORTE_GPR_SUBSCRIPTION", &tmp))) {
|
|
|
|
ORTE_ERROR_LOG(rc);
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
2005-06-24 20:59:37 +04:00
|
|
|
tmp = ORTE_GPR_TRIGGER;
|
2006-02-07 06:32:36 +03:00
|
|
|
if (ORTE_SUCCESS != (rc = orte_dss.register_type(orte_gpr_base_pack_trigger,
|
2005-06-24 20:59:37 +04:00
|
|
|
orte_gpr_base_unpack_trigger,
|
2006-02-07 06:32:36 +03:00
|
|
|
(orte_dss_copy_fn_t)orte_gpr_base_copy_trigger,
|
|
|
|
(orte_dss_compare_fn_t)orte_gpr_base_compare_trigger,
|
|
|
|
(orte_dss_size_fn_t)orte_gpr_base_size_trigger,
|
|
|
|
(orte_dss_print_fn_t)orte_gpr_base_print_trigger,
|
|
|
|
(orte_dss_release_fn_t)orte_gpr_base_std_obj_release,
|
|
|
|
ORTE_DSS_STRUCTURED,
|
2005-06-24 20:59:37 +04:00
|
|
|
"ORTE_GPR_TRIGGER", &tmp))) {
|
|
|
|
ORTE_ERROR_LOG(rc);
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
2005-05-01 04:58:06 +04:00
|
|
|
tmp = ORTE_GPR_NOTIFY_DATA;
|
2006-02-07 06:32:36 +03:00
|
|
|
if (ORTE_SUCCESS != (rc = orte_dss.register_type(orte_gpr_base_pack_notify_data,
|
2005-05-01 04:58:06 +04:00
|
|
|
orte_gpr_base_unpack_notify_data,
|
2006-02-07 06:32:36 +03:00
|
|
|
(orte_dss_copy_fn_t)orte_gpr_base_copy_notify_data,
|
|
|
|
(orte_dss_compare_fn_t)orte_gpr_base_compare_notify_data,
|
|
|
|
(orte_dss_size_fn_t)orte_gpr_base_size_notify_data,
|
|
|
|
(orte_dss_print_fn_t)orte_gpr_base_print_notify_data,
|
|
|
|
(orte_dss_release_fn_t)orte_gpr_base_std_obj_release,
|
|
|
|
ORTE_DSS_STRUCTURED,
|
2005-05-01 04:58:06 +04:00
|
|
|
"ORTE_GPR_NOTIFY_DATA", &tmp))) {
|
|
|
|
ORTE_ERROR_LOG(rc);
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
2005-07-18 22:49:00 +04:00
|
|
|
tmp = ORTE_GPR_NOTIFY_MSG;
|
2006-02-07 06:32:36 +03:00
|
|
|
if (ORTE_SUCCESS != (rc = orte_dss.register_type(orte_gpr_base_pack_notify_msg,
|
2005-07-18 22:49:00 +04:00
|
|
|
orte_gpr_base_unpack_notify_msg,
|
2006-02-07 06:32:36 +03:00
|
|
|
(orte_dss_copy_fn_t)orte_gpr_base_copy_notify_msg,
|
|
|
|
(orte_dss_compare_fn_t)orte_gpr_base_compare_notify_msg,
|
|
|
|
(orte_dss_size_fn_t)orte_gpr_base_size_notify_msg,
|
|
|
|
(orte_dss_print_fn_t)orte_gpr_base_print_notify_msg,
|
|
|
|
(orte_dss_release_fn_t)orte_gpr_base_std_obj_release,
|
|
|
|
ORTE_DSS_STRUCTURED,
|
2005-07-18 22:49:00 +04:00
|
|
|
"ORTE_GPR_NOTIFY_MSG", &tmp))) {
|
|
|
|
ORTE_ERROR_LOG(rc);
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
2005-03-24 23:23:15 +03:00
|
|
|
/* Open up all available components */
|
2006-02-12 04:33:29 +03:00
|
|
|
if (ORTE_SUCCESS !=
|
2005-09-01 05:07:30 +04:00
|
|
|
mca_base_components_open("gpr",
|
2005-08-15 22:25:35 +04:00
|
|
|
orte_gpr_base_output,
|
2005-09-01 05:07:30 +04:00
|
|
|
mca_gpr_base_static_components,
|
2005-04-13 07:19:48 +04:00
|
|
|
&orte_gpr_base_components_available, true)) {
|
2005-03-24 23:23:15 +03:00
|
|
|
return ORTE_ERROR;
|
|
|
|
}
|
2004-08-15 07:33:13 +04:00
|
|
|
|
2005-03-24 23:23:15 +03:00
|
|
|
/* All done */
|
2005-09-01 05:07:30 +04:00
|
|
|
|
2005-03-24 23:23:15 +03:00
|
|
|
return ORTE_SUCCESS;
|
2004-08-15 07:33:13 +04:00
|
|
|
}
|