f54fda489e
1. remove direct routed module (hooray!) 2. add radix tree routed module (binomial remains default) 3. remove duplicate data storage - orteds were storing nidmap and pidmap data in odls, everyone else in ess 4. add ess APIs to update nidmap, add new pidmap - used only by orteds for MPI-2 support 5. modify code to eliminate multiple calls to orte_routed.update_route that recreated info already in ess pidmap. Add ess API to lookup that info instead. Modify routed modules to utilize that capability 6. setup new ability to shutdown orteds without sending back an "ack" message to mpirun - not utilized yet, will require some changes to plm terminate_orteds functions in managed environments (coming soon) Initial tests indicating that fully routing comm via defined routing trees may not actually have a significant cost for operations like IB QP setup. More tests required to confirm. This will require an autogen... This commit was SVN r19866.
108 строки
2.9 KiB
C
108 строки
2.9 KiB
C
/*
|
|
* Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
|
|
* University Research and Technology
|
|
* Corporation. All rights reserved.
|
|
* Copyright (c) 2004-2006 The University of Tennessee and The University
|
|
* of Tennessee Research Foundation. All rights
|
|
* reserved.
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
* University of Stuttgart. All rights reserved.
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
* All rights reserved.
|
|
* $COPYRIGHT$
|
|
*
|
|
* Additional copyrights may follow
|
|
*
|
|
* $HEADER$
|
|
*/
|
|
/** @file:
|
|
*/
|
|
|
|
#ifndef MCA_ESS_BASE_H
|
|
#define MCA_ESS_BASE_H
|
|
|
|
#include "orte_config.h"
|
|
#include "orte/types.h"
|
|
|
|
#include "opal/mca/mca.h"
|
|
#include "opal/dss/dss_types.h"
|
|
#include "opal/class/opal_pointer_array.h"
|
|
#include "opal/class/opal_value_array.h"
|
|
|
|
#include "orte/runtime/orte_globals.h"
|
|
|
|
#include "orte/mca/ess/ess.h"
|
|
|
|
BEGIN_C_DECLS
|
|
|
|
/*
|
|
* Global functions for MCA overall collective open and close
|
|
*/
|
|
|
|
/**
|
|
* Open the ess framework
|
|
*/
|
|
ORTE_DECLSPEC int orte_ess_base_open(void);
|
|
|
|
/**
|
|
* Select a ess module
|
|
*/
|
|
ORTE_DECLSPEC int orte_ess_base_select(void);
|
|
|
|
/**
|
|
* Close the ess framework
|
|
*/
|
|
ORTE_DECLSPEC int orte_ess_base_close(void);
|
|
|
|
/*
|
|
* The verbose channel for debug output
|
|
*/
|
|
ORTE_DECLSPEC extern int orte_ess_base_output;
|
|
|
|
ORTE_DECLSPEC extern opal_list_t orte_ess_base_components_available;
|
|
|
|
#if !ORTE_DISABLE_FULL_SUPPORT
|
|
|
|
/*
|
|
* Internal helper functions used by components
|
|
*/
|
|
ORTE_DECLSPEC int orte_ess_env_get(void);
|
|
|
|
ORTE_DECLSPEC int orte_ess_base_std_prolog(void);
|
|
|
|
ORTE_DECLSPEC int orte_ess_base_app_setup(void);
|
|
ORTE_DECLSPEC int orte_ess_base_app_finalize(void);
|
|
ORTE_DECLSPEC void orte_ess_base_app_abort(int status, bool report) __opal_attribute_noreturn__;
|
|
|
|
ORTE_DECLSPEC int orte_ess_base_tool_setup(void);
|
|
ORTE_DECLSPEC int orte_ess_base_tool_finalize(void);
|
|
|
|
ORTE_DECLSPEC int orte_ess_base_orted_setup(void);
|
|
ORTE_DECLSPEC int orte_ess_base_orted_finalize(void);
|
|
|
|
/*
|
|
* Job/nid/pmap support
|
|
*/
|
|
ORTE_DECLSPEC int orte_ess_base_build_nidmap(opal_buffer_t *buffer,
|
|
opal_pointer_array_t *nidmap,
|
|
orte_jmap_t *jmap);
|
|
|
|
ORTE_DECLSPEC orte_pmap_t* orte_ess_base_lookup_pmap(opal_pointer_array_t *jobmap, orte_process_name_t *proc);
|
|
|
|
ORTE_DECLSPEC orte_nid_t* orte_ess_base_lookup_nid(opal_pointer_array_t *nidmap,
|
|
opal_pointer_array_t *jobmap,
|
|
orte_process_name_t *proc);
|
|
|
|
/*
|
|
* Put functions
|
|
*/
|
|
ORTE_DECLSPEC int orte_ess_env_put(orte_std_cntr_t num_procs,
|
|
orte_std_cntr_t num_local_procs,
|
|
char ***env);
|
|
|
|
#endif /* ORTE_DISABLE_FULL_SUPPORT */
|
|
|
|
END_C_DECLS
|
|
|
|
#endif
|