2005-08-31 05:43:48 +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.
|
|
|
|
* Copyright (c) 2004-2005 The University of Tennessee and The University
|
|
|
|
* of Tennessee Research Foundation. All rights
|
|
|
|
* reserved.
|
2005-08-31 05:43:48 +04:00
|
|
|
* 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$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef MCA_COLL_TUNED_TOPO_H_HAS_BEEN_INCLUDED
|
|
|
|
#define MCA_COLL_TUNED_TOPO_H_HAS_BEEN_INCLUDED
|
|
|
|
|
|
|
|
#include "ompi_config.h"
|
|
|
|
|
|
|
|
#if defined(c_plusplus) || defined(__cplusplus)
|
|
|
|
extern "C"
|
|
|
|
{
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define MAXTREEFANOUT 32
|
|
|
|
|
|
|
|
typedef struct ompi_coll_tree_t {
|
|
|
|
int32_t tree_root;
|
|
|
|
int32_t tree_fanout;
|
2005-09-03 05:41:13 +04:00
|
|
|
int32_t tree_bmtree;
|
2005-08-31 05:43:48 +04:00
|
|
|
int32_t tree_prev;
|
|
|
|
int32_t tree_next[MAXTREEFANOUT];
|
|
|
|
int32_t tree_nextsize;
|
|
|
|
} ompi_coll_tree_t;
|
|
|
|
|
|
|
|
typedef struct ompi_coll_chain_t {
|
|
|
|
int32_t chain_root;
|
|
|
|
int32_t chain_prev;
|
|
|
|
int32_t chain_next[MAXTREEFANOUT];
|
|
|
|
int32_t chain_nextsize;
|
|
|
|
int32_t chain_numchain;
|
|
|
|
} ompi_coll_chain_t;
|
|
|
|
|
|
|
|
ompi_coll_tree_t*
|
|
|
|
ompi_coll_tuned_topo_build_tree( int fanout,
|
|
|
|
struct ompi_communicator_t* com,
|
|
|
|
int root );
|
|
|
|
int ompi_coll_tuned_topo_destroy_tree( ompi_coll_tree_t** tree );
|
|
|
|
|
2005-09-03 05:41:13 +04:00
|
|
|
ompi_coll_tree_t*
|
2005-08-31 05:43:48 +04:00
|
|
|
ompi_coll_tuned_topo_build_bmtree( struct ompi_communicator_t* comm,
|
|
|
|
int root );
|
|
|
|
|
|
|
|
ompi_coll_chain_t*
|
|
|
|
ompi_coll_tuned_topo_build_chain( int fanout,
|
|
|
|
struct ompi_communicator_t* com,
|
|
|
|
int root );
|
|
|
|
int ompi_coll_tuned_topo_destroy_chain( ompi_coll_chain_t** chain );
|
|
|
|
|
2005-09-10 03:05:17 +04:00
|
|
|
/* debugging stuff, will be removed later */
|
|
|
|
int ompi_coll_tuned_topo_dump_tree (ompi_coll_tree_t* tree, int rank);
|
|
|
|
int ompi_coll_tuned_topo_dump_chain (ompi_coll_chain_t* chain, int rank);
|
|
|
|
|
2005-08-31 05:43:48 +04:00
|
|
|
#if defined(c_plusplus) || defined(__cplusplus)
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* MCA_COLL_TUNED_TOPO_H_HAS_BEEN_INCLUDED */
|
|
|
|
|