2004-05-20 13:54:14 +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.
|
|
|
|
* Copyright (c) 2004-2005 The University of Tennessee and The University
|
|
|
|
* 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.
|
2004-11-22 01:38:40 +00:00
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
2004-05-20 13:54:14 +00:00
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
2004-05-27 16:26:36 +00:00
|
|
|
/** @file:
|
2004-05-26 02:23:01 +00:00
|
|
|
*
|
2004-05-27 16:26:36 +00:00
|
|
|
* Populates global structure with system-specific information.
|
2004-06-12 10:56:32 +00:00
|
|
|
*
|
|
|
|
* Notes: add limits.h, compute size of integer and other types via sizeof(type)*CHAR_BIT
|
|
|
|
*
|
2004-05-20 17:38:54 +00:00
|
|
|
*/
|
|
|
|
|
2005-03-14 20:57:21 +00:00
|
|
|
#include "orte_config.h"
|
2004-05-27 16:26:36 +00:00
|
|
|
|
2004-10-20 01:03:09 +00:00
|
|
|
#ifdef HAVE_SYS_UTSNAME_H
|
2004-05-20 13:54:14 +00:00
|
|
|
#include <sys/utsname.h>
|
2004-10-20 01:03:09 +00:00
|
|
|
#endif
|
|
|
|
#ifdef HAVE_SYS_TYPES_H
|
2004-06-11 16:54:05 +00:00
|
|
|
#include <sys/types.h>
|
2004-10-20 01:03:09 +00:00
|
|
|
#endif
|
2004-05-20 13:54:14 +00:00
|
|
|
|
2005-03-14 20:57:21 +00:00
|
|
|
#ifndef _ORTE_SYS_INFO_H_
|
|
|
|
#define _ORTE_SYS_INFO_H_
|
2004-10-25 14:14:20 +00:00
|
|
|
|
2004-10-28 22:21:20 +00:00
|
|
|
#if defined(c_plusplus) || defined(__cplusplus)
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2004-05-27 16:26:36 +00:00
|
|
|
/**
|
|
|
|
* System information structure
|
|
|
|
*
|
2005-03-14 20:57:21 +00:00
|
|
|
* The orte_sys_info() function fills the sysname, nodename, release, version, machine,
|
2004-06-29 07:02:57 +00:00
|
|
|
* path_sep, and user fields
|
2004-05-27 16:26:36 +00:00
|
|
|
*
|
|
|
|
*/
|
2005-03-14 20:57:21 +00:00
|
|
|
struct orte_sys_info_t {
|
2004-05-27 16:26:36 +00:00
|
|
|
bool init; /**< Certifies that values have been filled.
|
2005-03-14 20:57:21 +00:00
|
|
|
* Certifies that the orte_sys_info() function has been
|
2004-05-27 16:26:36 +00:00
|
|
|
* called at least once so fields have valid values
|
|
|
|
*/
|
|
|
|
char *sysname; /**< Name of OS in use on this node. */
|
|
|
|
char *nodename; /**< Fully qualified host name on the network. */
|
|
|
|
char *release; /**< Release level of the operating system. */
|
|
|
|
char *version; /**< Version of the operating system release. */
|
|
|
|
char *machine; /**< Type of hardware composing this node. */
|
|
|
|
char *path_sep; /**< Path separation char, saved as string.
|
|
|
|
* The character used to separate directories in the path -
|
|
|
|
* a value that is usually either a '\' or '/', depending
|
|
|
|
* upon the operating system
|
|
|
|
*/
|
|
|
|
char *user; /**< User id on this system. */
|
|
|
|
char *suffix; /**< Automatic suffix added to file names.
|
|
|
|
* Some computing environments automatically "tag" files
|
|
|
|
* created by applications with a computer-generated suffix
|
|
|
|
* to ensure uniqueness of the file name. This field records
|
|
|
|
* that value for future use.
|
|
|
|
*/
|
2004-05-20 21:28:59 +00:00
|
|
|
};
|
2005-03-14 20:57:21 +00:00
|
|
|
typedef struct orte_sys_info_t orte_sys_info_t;
|
2004-05-20 13:54:14 +00:00
|
|
|
|
2005-03-14 20:57:21 +00:00
|
|
|
OMPI_DECLSPEC extern orte_sys_info_t orte_system_info;
|
2004-05-20 13:54:14 +00:00
|
|
|
|
2004-08-10 04:59:34 +00:00
|
|
|
|
2004-05-26 19:11:55 +00:00
|
|
|
/**
|
2004-08-10 04:59:34 +00:00
|
|
|
* \internal
|
|
|
|
*
|
|
|
|
* Discover and record a wide range of information about the system
|
2005-03-14 20:57:21 +00:00
|
|
|
* upon which this code is executing. orte_sys_info populates a global
|
2004-08-10 04:59:34 +00:00
|
|
|
* variable with information about the system upon which the process
|
|
|
|
* is executing.
|
|
|
|
*
|
2005-03-14 20:57:21 +00:00
|
|
|
* Called from \c orte_init.
|
2004-05-26 19:11:55 +00:00
|
|
|
*
|
2005-03-14 20:57:21 +00:00
|
|
|
* @retval ORTE_SUCCESS If values are successfully determined.
|
|
|
|
* @retval ORTE_ERROR If the system does not provide the requested information.
|
2004-05-27 16:26:36 +00:00
|
|
|
*/
|
2005-03-14 20:57:21 +00:00
|
|
|
OMPI_DECLSPEC int orte_sys_info(void);
|
2004-10-28 22:21:20 +00:00
|
|
|
|
2005-03-18 23:40:08 +00:00
|
|
|
/*
|
|
|
|
* \internal
|
|
|
|
*
|
|
|
|
* Free any memory held in the system_info structure
|
|
|
|
*
|
|
|
|
* Called from \c orte_finalize
|
|
|
|
*
|
|
|
|
* @retval ORTE_SUCCESS If all values successfully released
|
|
|
|
* @retval ORTE_ERROR If any problems occur
|
|
|
|
*/
|
|
|
|
OMPI_DECLSPEC int orte_sys_info_finalize(void);
|
|
|
|
|
2004-10-28 22:21:20 +00:00
|
|
|
#if defined(c_plusplus) || defined(__cplusplus)
|
|
|
|
}
|
|
|
|
#endif
|
2004-10-25 14:14:20 +00:00
|
|
|
#endif
|