2005-05-19 13:33:55 +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.
|
2005-09-07 18:52:28 +00:00
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
2005-05-19 13:33:55 +00:00
|
|
|
* University of Stuttgart. All rights reserved.
|
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
|
|
|
* $COPYRIGHT$
|
2005-09-07 18:52:28 +00:00
|
|
|
*
|
2005-05-19 13:33:55 +00:00
|
|
|
* Additional copyrights may follow
|
2005-09-07 18:52:28 +00:00
|
|
|
*
|
2005-05-19 13:33:55 +00:00
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
|
|
|
/** @file **/
|
|
|
|
|
2005-05-22 18:40:03 +00:00
|
|
|
#include "orte_config.h"
|
|
|
|
|
2005-07-04 01:36:20 +00:00
|
|
|
#include "opal/util/malloc.h"
|
2005-07-03 23:31:27 +00:00
|
|
|
#include "opal/util/output.h"
|
2005-09-07 18:52:28 +00:00
|
|
|
#include "opal/util/trace.h"
|
2005-10-05 13:56:35 +00:00
|
|
|
#include "opal/util/show_help.h"
|
2005-08-09 22:40:42 +00:00
|
|
|
#include "opal/memory/memory.h"
|
2005-08-12 20:46:25 +00:00
|
|
|
#include "opal/mca/base/base.h"
|
|
|
|
#include "opal/runtime/opal.h"
|
2005-08-14 17:23:34 +00:00
|
|
|
#include "opal/mca/memory/base/base.h"
|
2005-08-16 16:15:53 +00:00
|
|
|
#include "opal/mca/paffinity/base/base.h"
|
2005-08-18 05:34:22 +00:00
|
|
|
#include "opal/mca/timer/base/base.h"
|
2005-08-22 03:05:39 +00:00
|
|
|
#include "opal/include/constants.h"
|
|
|
|
#include "opal/util/error.h"
|
|
|
|
|
2005-09-07 18:52:28 +00:00
|
|
|
|
2005-08-22 03:05:39 +00:00
|
|
|
static const char *
|
|
|
|
opal_err2str(int errnum)
|
|
|
|
{
|
|
|
|
const char *retval;
|
|
|
|
|
|
|
|
switch (errnum) {
|
|
|
|
case OPAL_SUCCESS:
|
|
|
|
retval = "Success";
|
|
|
|
break;
|
|
|
|
case OPAL_ERROR:
|
|
|
|
retval = "Error";
|
|
|
|
break;
|
|
|
|
case OPAL_ERR_OUT_OF_RESOURCE:
|
|
|
|
retval = "Out of resource";
|
|
|
|
break;
|
|
|
|
case OPAL_ERR_NOT_FOUND:
|
|
|
|
retval = "Not found";
|
|
|
|
break;
|
|
|
|
case OPAL_ERR_BAD_PARAM:
|
|
|
|
retval = "Bad parameter";
|
|
|
|
break;
|
2005-09-07 18:52:28 +00:00
|
|
|
default:
|
2005-08-22 03:05:39 +00:00
|
|
|
retval = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
return retval;
|
|
|
|
}
|
2005-08-18 05:34:22 +00:00
|
|
|
|
2005-05-19 13:33:55 +00:00
|
|
|
|
|
|
|
/**
|
2005-05-22 18:40:03 +00:00
|
|
|
* Initialize the OPAL utilities
|
2005-05-19 13:33:55 +00:00
|
|
|
*
|
2005-08-22 03:05:39 +00:00
|
|
|
* @retval OPAL_SUCCESS Upon success.
|
|
|
|
* @retval OPAL_ERROR Upon failure.
|
2005-05-19 13:33:55 +00:00
|
|
|
*
|
2005-09-07 18:52:28 +00:00
|
|
|
* This function performs
|
2005-05-19 13:33:55 +00:00
|
|
|
*/
|
2005-05-22 18:40:03 +00:00
|
|
|
int opal_init(void)
|
|
|
|
{
|
2005-10-05 13:56:35 +00:00
|
|
|
int ret;
|
|
|
|
char *error = NULL;
|
|
|
|
|
2005-05-22 18:40:03 +00:00
|
|
|
/* initialize the memory allocator */
|
2005-07-04 01:36:20 +00:00
|
|
|
opal_malloc_init();
|
2005-05-22 18:40:03 +00:00
|
|
|
|
|
|
|
/* initialize the output system */
|
2005-07-03 23:31:27 +00:00
|
|
|
opal_output_init();
|
2005-08-22 03:05:39 +00:00
|
|
|
|
2005-09-07 18:52:28 +00:00
|
|
|
/* init the trace function */
|
|
|
|
opal_trace_init();
|
|
|
|
|
2005-08-22 03:05:39 +00:00
|
|
|
/* register handler for errnum -> string converstion */
|
2005-10-05 13:56:35 +00:00
|
|
|
if (OPAL_SUCCESS != (ret = opal_error_register("OPAL",
|
|
|
|
OPAL_ERR_BASE, OPAL_ERR_MAX, opal_err2str))) {
|
|
|
|
error = "opal_error_register";
|
|
|
|
goto error;
|
|
|
|
}
|
2005-08-24 20:19:36 +00:00
|
|
|
|
2005-05-22 18:40:03 +00:00
|
|
|
/* initialize the mca */
|
2005-10-05 13:56:35 +00:00
|
|
|
if (OMPI_SUCCESS != (ret = mca_base_open())) {
|
|
|
|
error = "mca_base_open";
|
|
|
|
goto error;
|
|
|
|
}
|
2005-05-19 13:33:55 +00:00
|
|
|
|
2005-08-16 16:15:53 +00:00
|
|
|
/* open the processor affinity base */
|
2005-10-05 18:08:06 +00:00
|
|
|
opal_paffinity_base_open();
|
|
|
|
opal_paffinity_base_select();
|
2005-08-16 16:15:53 +00:00
|
|
|
|
2005-08-14 17:23:34 +00:00
|
|
|
/* open the memory manager components. Memory hooks may be
|
|
|
|
triggered before this (any time after mem_free_init(),
|
|
|
|
actually). This is a hook available for memory manager hooks
|
|
|
|
without good initialization routine support */
|
2005-10-05 13:56:35 +00:00
|
|
|
if (OPAL_SUCCESS != (ret = opal_memory_base_open())) {
|
|
|
|
error = "opal_memory_base_open";
|
|
|
|
goto error;
|
|
|
|
}
|
2005-08-14 17:23:34 +00:00
|
|
|
|
2005-09-26 20:20:20 +00:00
|
|
|
/* initialize the memory manager / tracker */
|
2005-10-05 13:56:35 +00:00
|
|
|
if (OPAL_SUCCESS != opal_mem_free_init()) {
|
|
|
|
error = "opal_mem_free_init";
|
|
|
|
goto error;
|
|
|
|
}
|
2005-09-26 20:20:20 +00:00
|
|
|
|
2005-10-05 13:56:35 +00:00
|
|
|
if (OPAL_SUCCESS != (ret = opal_timer_base_open())) {
|
|
|
|
error = "opal_timer_base_open";
|
|
|
|
goto error;
|
|
|
|
}
|
|
|
|
|
|
|
|
error:
|
|
|
|
if (ret != OPAL_SUCCESS) {
|
|
|
|
opal_show_help("help-opal-runtime",
|
2005-10-21 20:04:18 +00:00
|
|
|
"opal_init:startup:internal-failure", true,
|
2005-10-05 13:56:35 +00:00
|
|
|
error, ret);
|
|
|
|
}
|
2005-08-18 05:34:22 +00:00
|
|
|
|
2005-10-05 13:56:35 +00:00
|
|
|
return ret;
|
2005-05-22 18:40:03 +00:00
|
|
|
}
|
2005-06-08 19:03:29 +00:00
|
|
|
|