2007-12-21 06:02:00 +00:00
|
|
|
/* -*- Mode: C; c-basic-offset:4 ; -*- */
|
2004-01-10 08:20:36 +00:00
|
|
|
/*
|
2005-11-05 19:57:48 +00:00
|
|
|
* Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
|
|
|
|
* University Research and Technology
|
|
|
|
* Corporation. All rights reserved.
|
2007-12-21 06:02:00 +00:00
|
|
|
* Copyright (c) 2004-2007 The University of Tennessee and The University
|
2005-11-05 19:57:48 +00:00
|
|
|
* of Tennessee Research Foundation. All rights
|
|
|
|
* reserved.
|
2004-11-28 20:09:25 +00:00
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
|
|
* University of Stuttgart. All rights reserved.
|
2005-03-24 12:43:37 +00:00
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
2008-02-28 01:57:57 +00:00
|
|
|
* Copyright (c) 2007 Cisco Systems, Inc. All rights reserved.
|
2004-11-22 01:38:40 +00:00
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
2004-01-10 08:20:36 +00:00
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
2004-06-07 15:33:53 +00:00
|
|
|
#ifndef OMPI_INFO_H
|
|
|
|
#define OMPI_INFO_H
|
2004-01-10 08:20:36 +00:00
|
|
|
|
2004-02-10 00:09:36 +00:00
|
|
|
#include <string.h>
|
|
|
|
|
2004-01-10 08:20:36 +00:00
|
|
|
#include "mpi.h"
|
2005-07-04 02:38:44 +00:00
|
|
|
#include "opal/util/strncpy.h"
|
2005-07-03 16:22:16 +00:00
|
|
|
#include "opal/class/opal_list.h"
|
2007-12-21 06:02:00 +00:00
|
|
|
#include "opal/class/opal_pointer_array.h"
|
2005-07-03 22:45:48 +00:00
|
|
|
#include "opal/threads/mutex.h"
|
2004-02-03 22:03:22 +00:00
|
|
|
|
2004-01-10 08:20:36 +00:00
|
|
|
|
2004-02-01 22:27:22 +00:00
|
|
|
/**
|
2004-08-12 16:56:24 +00:00
|
|
|
* \internal
|
2004-06-07 15:33:53 +00:00
|
|
|
* ompi_info_t structure. MPI_Info is a pointer to this structure
|
2004-02-01 22:27:22 +00:00
|
|
|
*/
|
2004-06-07 15:33:53 +00:00
|
|
|
struct ompi_info_t {
|
2005-07-03 16:22:16 +00:00
|
|
|
opal_list_t super;
|
2004-08-12 16:56:24 +00:00
|
|
|
/**< generic list pointer which is the container for (key,value)
|
|
|
|
pairs */
|
2004-08-14 01:56:05 +00:00
|
|
|
int i_f_to_c_index;
|
2004-08-12 16:56:24 +00:00
|
|
|
/**< fortran handle for info. This is needed for translation from
|
|
|
|
fortran to C and vice versa */
|
2005-07-03 22:45:48 +00:00
|
|
|
opal_mutex_t *i_lock;
|
2004-08-12 16:56:24 +00:00
|
|
|
/**< Mutex for thread safety */
|
|
|
|
bool i_freed;
|
|
|
|
/**< Whether this info has been freed or not */
|
2004-01-10 17:10:29 +00:00
|
|
|
};
|
2004-08-12 16:56:24 +00:00
|
|
|
/**
|
|
|
|
* \internal
|
|
|
|
* Convenience typedef
|
|
|
|
*/
|
2004-06-07 15:33:53 +00:00
|
|
|
typedef struct ompi_info_t ompi_info_t;
|
2004-01-10 08:20:36 +00:00
|
|
|
|
2004-02-01 22:27:22 +00:00
|
|
|
/**
|
2004-08-12 16:56:24 +00:00
|
|
|
* \internal
|
|
|
|
*
|
2004-06-07 15:33:53 +00:00
|
|
|
* ompi_info_entry_t object. Each item in ompi_info_list is of this
|
2004-02-01 22:27:22 +00:00
|
|
|
* type. It contains (key,value) pairs
|
|
|
|
*/
|
2004-06-07 15:33:53 +00:00
|
|
|
struct ompi_info_entry_t {
|
2005-07-03 16:22:16 +00:00
|
|
|
opal_list_item_t super; /**< required for opal_list_t type */
|
2004-02-03 22:03:22 +00:00
|
|
|
char *ie_value; /**< value part of the (key, value) pair.
|
2004-02-01 22:27:22 +00:00
|
|
|
* Maximum length is MPI_MAX_INFO_VAL */
|
2004-02-03 22:03:22 +00:00
|
|
|
char ie_key[MPI_MAX_INFO_KEY + 1]; /**< "key" part of the (key, value)
|
2004-02-01 22:27:22 +00:00
|
|
|
* pair */
|
|
|
|
};
|
2004-08-12 16:56:24 +00:00
|
|
|
/**
|
|
|
|
* \internal
|
|
|
|
* Convenience typedef
|
|
|
|
*/
|
2004-06-07 15:33:53 +00:00
|
|
|
typedef struct ompi_info_entry_t ompi_info_entry_t;
|
2004-02-01 22:27:22 +00:00
|
|
|
|
2007-12-21 06:02:00 +00:00
|
|
|
BEGIN_C_DECLS
|
2004-08-12 16:56:24 +00:00
|
|
|
|
2007-12-21 06:02:00 +00:00
|
|
|
/**
|
|
|
|
* Table for Fortran <-> C translation table
|
|
|
|
*/
|
|
|
|
extern opal_pointer_array_t ompi_info_f_to_c_table;
|
2004-08-12 16:56:24 +00:00
|
|
|
|
2007-12-21 06:02:00 +00:00
|
|
|
/**
|
|
|
|
* Global instance for MPI_INFO_NULL
|
|
|
|
*/
|
|
|
|
OMPI_DECLSPEC extern ompi_info_t ompi_mpi_info_null;
|
2004-08-12 16:56:24 +00:00
|
|
|
|
2007-12-21 06:02:00 +00:00
|
|
|
/**
|
|
|
|
* \internal
|
|
|
|
* Some declarations needed to use OBJ_NEW and OBJ_DESTRUCT macros
|
|
|
|
*/
|
|
|
|
OMPI_DECLSPEC OBJ_CLASS_DECLARATION(ompi_info_t);
|
2004-02-03 22:03:22 +00:00
|
|
|
|
2007-12-21 06:02:00 +00:00
|
|
|
/**
|
|
|
|
* \internal
|
|
|
|
* Some declarations needed to use OBJ_NEW and OBJ_DESTRUCT macros
|
|
|
|
*/
|
|
|
|
OMPI_DECLSPEC OBJ_CLASS_DECLARATION(ompi_info_entry_t);
|
2004-08-12 16:56:24 +00:00
|
|
|
|
2007-12-21 06:02:00 +00:00
|
|
|
/**
|
|
|
|
* This function is invoked during ompi_mpi_init() and sets up
|
|
|
|
* MPI_Info handling.
|
|
|
|
*/
|
|
|
|
int ompi_info_init(void);
|
2004-08-12 16:56:24 +00:00
|
|
|
|
2007-12-21 06:02:00 +00:00
|
|
|
/**
|
|
|
|
* This functions is called during ompi_mpi_finalize() and shuts
|
|
|
|
* down MPI_Info handling.
|
|
|
|
*/
|
|
|
|
int ompi_info_finalize(void);
|
2004-08-12 16:56:24 +00:00
|
|
|
|
2007-12-21 06:02:00 +00:00
|
|
|
/**
|
|
|
|
* ompi_info_dup - Duplicate an 'MPI_Info' object
|
|
|
|
*
|
|
|
|
* @param info source info object (handle)
|
|
|
|
* @param newinfo pointer to the new info object (handle)
|
|
|
|
*
|
|
|
|
* @retval MPI_SUCCESS upon success
|
|
|
|
* @retval MPI_ERR_NO_MEM if out of memory
|
|
|
|
*
|
|
|
|
* Not only will the (key, value) pairs be duplicated, the order
|
|
|
|
* of keys will be the same in 'newinfo' as it is in 'info'. When
|
|
|
|
* an info object is no longer being used, it should be freed with
|
|
|
|
* 'MPI_Info_free'.
|
|
|
|
*/
|
|
|
|
int ompi_info_dup (ompi_info_t *info, ompi_info_t **newinfo);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Set a new key,value pair on info.
|
|
|
|
*
|
|
|
|
* @param info pointer to ompi_info_t object
|
|
|
|
* @param key pointer to the new key object
|
|
|
|
* @param value pointer to the new value object
|
|
|
|
*
|
|
|
|
* @retval MPI_SUCCESS upon success
|
|
|
|
* @retval MPI_ERR_NO_MEM if out of memory
|
|
|
|
*/
|
|
|
|
int ompi_info_set (ompi_info_t *info, char *key, char *value);
|
2004-08-12 16:56:24 +00:00
|
|
|
|
2007-12-21 06:02:00 +00:00
|
|
|
/**
|
|
|
|
* ompi_info_free - Free an 'MPI_Info' object.
|
|
|
|
*
|
|
|
|
* @param info pointer to info (ompi_info_t *) object to be freed (handle)
|
|
|
|
*
|
|
|
|
* @retval MPI_SUCCESS
|
|
|
|
* @retval MPI_ERR_ARG
|
|
|
|
*
|
|
|
|
* Upon successful completion, 'info' will be set to
|
|
|
|
* 'MPI_INFO_NULL'. Free the info handle and all of its keys and
|
|
|
|
* values.
|
|
|
|
*/
|
|
|
|
int ompi_info_free (ompi_info_t **info);
|
2004-08-12 16:56:24 +00:00
|
|
|
|
2008-02-28 01:57:57 +00:00
|
|
|
/**
|
|
|
|
* Get a (key, value) pair from an 'MPI_Info' object and assign it
|
|
|
|
* into a boolen output.
|
|
|
|
*
|
|
|
|
* @param info Pointer to ompi_info_t object
|
|
|
|
* @param key null-terminated character string of the index key
|
|
|
|
* @param value Boolean output value
|
|
|
|
* @param flag true (1) if 'key' defined on 'info', false (0) if not
|
|
|
|
* (logical)
|
|
|
|
*
|
|
|
|
* @retval MPI_SUCCESS
|
|
|
|
*
|
|
|
|
* If found, the string value will be cast to the boolen output in
|
|
|
|
* the following manner:
|
|
|
|
*
|
|
|
|
* - If the string value is digits, the return value is "(bool)
|
|
|
|
* atoi(value)"
|
|
|
|
* - If the string value is (case-insensitive) "yes" or "true", the
|
|
|
|
* result is true
|
|
|
|
* - If the string value is (case-insensitive) "no" or "false", the
|
|
|
|
* result is false
|
|
|
|
* - All other values are false
|
|
|
|
*/
|
|
|
|
OMPI_DECLSPEC int ompi_info_get_bool (ompi_info_t *info, char *key, bool *value,
|
|
|
|
int *flag);
|
|
|
|
|
2007-12-21 06:02:00 +00:00
|
|
|
/**
|
|
|
|
* Get a (key, value) pair from an 'MPI_Info' object
|
|
|
|
*
|
|
|
|
* @param info Pointer to ompi_info_t object
|
|
|
|
* @param key null-terminated character string of the index key
|
|
|
|
* @param valuelen maximum length of 'value' (integer)
|
|
|
|
* @param value null-terminated character string of the value
|
|
|
|
* @param flag true (1) if 'key' defined on 'info', false (0) if not
|
|
|
|
* (logical)
|
|
|
|
*
|
|
|
|
* @retval MPI_SUCCESS
|
|
|
|
*
|
|
|
|
* In C and C++, 'valuelen' should be one less than the allocated
|
|
|
|
* space to allow for for the null terminator.
|
|
|
|
*/
|
2008-02-28 01:57:57 +00:00
|
|
|
OMPI_DECLSPEC int ompi_info_get (ompi_info_t *info, char *key, int valuelen,
|
|
|
|
char *value, int *flag);
|
2004-08-12 16:56:24 +00:00
|
|
|
|
2007-12-21 06:02:00 +00:00
|
|
|
/**
|
|
|
|
* Delete a (key,value) pair from "info"
|
|
|
|
*
|
|
|
|
* @param info ompi_info_t pointer on which we need to operate
|
|
|
|
* @param key The key portion of the (key,value) pair that
|
|
|
|
* needs to be deleted
|
|
|
|
*
|
|
|
|
* @retval MPI_SUCCESS
|
|
|
|
* @retval MPI_ERR_NOKEY
|
|
|
|
*/
|
|
|
|
int ompi_info_delete (ompi_info_t *info, char *key);
|
2004-08-12 16:56:24 +00:00
|
|
|
|
2007-12-21 06:02:00 +00:00
|
|
|
/**
|
|
|
|
* @param info - ompi_info_t pointer object (handle)
|
|
|
|
* @param key - null-terminated character string of the index key
|
|
|
|
* @param valuelen - length of the value associated with 'key' (integer)
|
|
|
|
* @param flag - true (1) if 'key' defined on 'info', false (0) if not
|
|
|
|
* (logical)
|
|
|
|
*
|
|
|
|
* @retval MPI_SUCCESS
|
|
|
|
* @retval MPI_ERR_ARG
|
|
|
|
* @retval MPI_ERR_INFO_KEY
|
|
|
|
*
|
|
|
|
* The length returned in C and C++ does not include the end-of-string
|
|
|
|
* character. If the 'key' is not found on 'info', 'valuelen' is left
|
|
|
|
* alone.
|
|
|
|
*/
|
|
|
|
OMPI_DECLSPEC int ompi_info_get_valuelen (ompi_info_t *info, char *key, int *valuelen,
|
2004-08-12 16:56:24 +00:00
|
|
|
int *flag);
|
|
|
|
|
2007-12-21 06:02:00 +00:00
|
|
|
/**
|
|
|
|
* ompi_info_get_nthkey - Get a key indexed by integer from an 'MPI_Info' o
|
|
|
|
*
|
|
|
|
* @param info Pointer to ompi_info_t object
|
|
|
|
* @param n index of key to retrieve (integer)
|
|
|
|
* @param key character string of at least 'MPI_MAX_INFO_KEY' characters
|
|
|
|
*
|
|
|
|
* @retval MPI_SUCCESS
|
|
|
|
* @retval MPI_ERR_ARG
|
|
|
|
*/
|
|
|
|
int ompi_info_get_nthkey (ompi_info_t *info, int n, char *key);
|
2006-01-28 15:38:37 +00:00
|
|
|
|
2007-12-21 06:02:00 +00:00
|
|
|
/**
|
|
|
|
* Convert value string to boolean
|
|
|
|
*
|
|
|
|
* Convert value string \c value into a boolean, using the
|
|
|
|
* interpretation rules specified in MPI-2 Section 4.10. The
|
|
|
|
* strings "true", "false", and integer numbers can be converted
|
|
|
|
* into booleans. All others will return \c OMPI_ERR_BAD_PARAM
|
|
|
|
*
|
|
|
|
* @param value Value string for info key to interpret
|
|
|
|
* @param interp returned interpretation of the value key
|
|
|
|
*
|
|
|
|
* @retval OMPI_SUCCESS string was successfully interpreted
|
|
|
|
* @retval OMPI_ERR_BAD_PARAM string was not able to be interpreted
|
|
|
|
*/
|
2008-03-05 12:46:59 +00:00
|
|
|
OMPI_DECLSPEC int ompi_info_value_to_bool(char *value, bool *interp);
|
2006-01-28 15:38:37 +00:00
|
|
|
|
2007-12-21 06:02:00 +00:00
|
|
|
/**
|
|
|
|
* Convert value string to integer
|
|
|
|
*
|
|
|
|
* Convert value string \c value into a integer, using the
|
|
|
|
* interpretation rules specified in MPI-2 Section 4.10.
|
|
|
|
* All others will return \c OMPI_ERR_BAD_PARAM
|
|
|
|
*
|
|
|
|
* @param value Value string for info key to interpret
|
|
|
|
* @param interp returned interpretation of the value key
|
|
|
|
*
|
|
|
|
* @retval OMPI_SUCCESS string was successfully interpreted
|
|
|
|
* @retval OMPI_ERR_BAD_PARAM string was not able to be interpreted
|
|
|
|
*/
|
2007-12-21 15:06:59 +00:00
|
|
|
int ompi_info_value_to_int(char *value, int *interp);
|
2004-02-03 22:03:22 +00:00
|
|
|
|
2007-12-21 06:02:00 +00:00
|
|
|
END_C_DECLS
|
2004-08-12 16:56:24 +00:00
|
|
|
|
2004-02-03 22:03:22 +00:00
|
|
|
/**
|
2004-08-12 16:56:24 +00:00
|
|
|
* Return whether this info has been freed already or not.
|
2004-02-03 22:03:22 +00:00
|
|
|
*
|
2004-08-12 16:56:24 +00:00
|
|
|
* @param info Pointer to ompi_info_t object.
|
2004-02-03 22:03:22 +00:00
|
|
|
*
|
2004-08-12 16:56:24 +00:00
|
|
|
* @retval true If the info has already been freed
|
|
|
|
* @retval false If the info has not yet been freed
|
2004-02-03 22:03:22 +00:00
|
|
|
*
|
2004-08-12 16:56:24 +00:00
|
|
|
* If the info has been freed, return true. This will likely only
|
|
|
|
* happen in a reliable manner if ompi_debug_handle_never_free is
|
|
|
|
* true, in which case an extra OBJ_RETAIN is set on the object during
|
|
|
|
* OBJ_NEW, meaning that the user will never be able to actually free
|
|
|
|
* the underlying object. It's a good way to find out if a process is
|
|
|
|
* unintentionally using a freed handle.
|
2004-02-03 22:03:22 +00:00
|
|
|
*/
|
2004-08-12 16:56:24 +00:00
|
|
|
static inline bool ompi_info_is_freed(ompi_info_t *info)
|
|
|
|
{
|
|
|
|
return info->i_freed;
|
2004-02-03 22:03:22 +00:00
|
|
|
}
|
|
|
|
|
2004-08-12 16:56:24 +00:00
|
|
|
|
2004-02-11 15:30:51 +00:00
|
|
|
/**
|
|
|
|
* Get the number of keys defined on on an MPI_Info object
|
2004-06-07 15:33:53 +00:00
|
|
|
* @param info Pointer to ompi_info_t object.
|
2004-02-11 15:30:51 +00:00
|
|
|
* @param nkeys Pointer to nkeys, which needs to be filled up.
|
|
|
|
*
|
|
|
|
* @retval The number of keys defined on info
|
|
|
|
*/
|
|
|
|
static inline int
|
2004-08-12 16:56:24 +00:00
|
|
|
ompi_info_get_nkeys(ompi_info_t *info, int *nkeys)
|
|
|
|
{
|
2005-07-03 16:22:16 +00:00
|
|
|
*nkeys = (int) opal_list_get_size(&(info->super));
|
2004-02-11 15:30:51 +00:00
|
|
|
return MPI_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2004-06-07 15:33:53 +00:00
|
|
|
#endif /* OMPI_INFO_H */
|