2008-01-23 12:20:34 +03:00
|
|
|
/* -*- C -*-
|
|
|
|
*
|
|
|
|
* 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.
|
2015-06-24 06:59:57 +03:00
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
2008-01-23 12:20:34 +03:00
|
|
|
* University of Stuttgart. All rights reserved.
|
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
|
|
|
* $COPYRIGHT$
|
2015-06-24 06:59:57 +03:00
|
|
|
*
|
2008-01-23 12:20:34 +03:00
|
|
|
* Additional copyrights may follow
|
2015-06-24 06:59:57 +03:00
|
|
|
*
|
2008-01-23 12:20:34 +03:00
|
|
|
* $HEADER$
|
|
|
|
*
|
|
|
|
* The most basic of MPI applications
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define bool int
|
|
|
|
#define false 0
|
|
|
|
#define true 1
|
|
|
|
|
|
|
|
|
|
|
|
#include <mpi.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include "../../opal/mca/carto/carto.h"
|
|
|
|
#include "../../opal/mca/carto/base/base.h"
|
|
|
|
#include "../../opal/util/output.h"
|
2009-06-09 19:02:57 +04:00
|
|
|
#include "../../opal/class/opal_graph.h"
|
2008-01-23 12:20:34 +03:00
|
|
|
|
|
|
|
int
|
|
|
|
main(int argc, char* argv[])
|
|
|
|
{
|
|
|
|
int rank, size, distance, distance_array_size, i;
|
|
|
|
opal_carto_graph_t *graph;
|
|
|
|
opal_carto_base_node_t *slot0, *end_node;
|
|
|
|
opal_carto_node_distance_t *node_distance;
|
|
|
|
opal_value_array_t *distance_array;
|
|
|
|
|
|
|
|
MPI_Init(&argc, &argv);
|
|
|
|
MPI_Comm_rank(MPI_COMM_WORLD, &rank);
|
|
|
|
MPI_Comm_size(MPI_COMM_WORLD, &size);
|
|
|
|
|
|
|
|
|
|
|
|
printf("Hello, world, I am %d of %d\n", rank, size);
|
|
|
|
if (0 == rank) {
|
|
|
|
/**
|
2015-06-24 06:59:57 +03:00
|
|
|
*
|
2008-01-23 12:20:34 +03:00
|
|
|
*/
|
|
|
|
|
|
|
|
opal_output(0," \n\nget_host_graph Full\n");
|
2008-05-07 23:33:49 +04:00
|
|
|
opal_carto_base_get_host_graph(&graph,NULL);
|
2008-01-23 12:20:34 +03:00
|
|
|
opal_graph_print(graph);
|
2008-05-07 23:33:49 +04:00
|
|
|
slot0 = opal_carto_base_find_node(graph, "slot0");
|
2008-01-23 12:20:34 +03:00
|
|
|
if (NULL == slot0) {
|
|
|
|
opal_output(0,"couldnt find slot0 in the graph exiting\n");
|
2008-05-07 23:33:49 +04:00
|
|
|
opal_carto_base_free_graph(graph);
|
2008-01-23 12:20:34 +03:00
|
|
|
return -1;
|
|
|
|
}
|
2008-05-07 23:33:49 +04:00
|
|
|
end_node = opal_carto_base_find_node(graph, "slot3");
|
2008-01-23 12:20:34 +03:00
|
|
|
if (NULL == end_node) {
|
|
|
|
opal_output(0,"couldnt find mthca1 in the graph exiting\n");
|
2008-05-07 23:33:49 +04:00
|
|
|
opal_carto_base_free_graph(graph);
|
2008-01-23 12:20:34 +03:00
|
|
|
return -1;
|
|
|
|
}
|
2008-05-07 23:33:49 +04:00
|
|
|
distance = opal_carto_base_spf(graph, slot0, end_node);
|
2008-01-23 12:20:34 +03:00
|
|
|
opal_output(0,"\nThe distance between slot0 and slot3 is %d\n",distance);
|
|
|
|
distance_array = OBJ_NEW(opal_value_array_t);
|
|
|
|
opal_value_array_init(distance_array, sizeof(opal_carto_node_distance_t));
|
|
|
|
opal_value_array_reserve(distance_array, 50);
|
2008-05-07 23:33:49 +04:00
|
|
|
distance_array_size = opal_carto_base_get_nodes_distance(graph, slot0, NULL, distance_array);
|
2008-01-23 12:20:34 +03:00
|
|
|
for (i=0; i < distance_array_size; i++) {
|
|
|
|
node_distance = opal_value_array_get_item(distance_array, i);
|
|
|
|
opal_output(0,"Node %s distance from slot0 is %d\n",node_distance->node->node_name, node_distance->node_distance);
|
|
|
|
}
|
|
|
|
OBJ_RELEASE(distance_array);
|
2008-05-07 23:33:49 +04:00
|
|
|
opal_carto_base_free_graph(graph);
|
2008-01-23 12:20:34 +03:00
|
|
|
/**
|
2015-06-24 06:59:57 +03:00
|
|
|
*
|
2008-01-23 12:20:34 +03:00
|
|
|
*/
|
|
|
|
|
|
|
|
opal_output(0," \n\nget_host_graph Infiniband\n");
|
2008-05-07 23:33:49 +04:00
|
|
|
opal_carto_base_get_host_graph(&graph,"Infiniband");
|
2008-01-23 12:20:34 +03:00
|
|
|
opal_graph_print(graph);
|
2008-05-07 23:33:49 +04:00
|
|
|
slot0 = opal_carto_base_find_node(graph, "slot0");
|
2008-01-23 12:20:34 +03:00
|
|
|
if (NULL == slot0) {
|
|
|
|
opal_output(0,"couldnt find slot0 in the graph exiting\n");
|
2008-05-07 23:33:49 +04:00
|
|
|
opal_carto_base_free_graph(graph);
|
2008-01-23 12:20:34 +03:00
|
|
|
return -1;
|
|
|
|
}
|
2008-05-07 23:33:49 +04:00
|
|
|
end_node = opal_carto_base_find_node(graph, "mthca1");
|
2008-01-23 12:20:34 +03:00
|
|
|
if (NULL == end_node) {
|
|
|
|
opal_output(0,"couldnt find mthca1 in the graph exiting\n");
|
2008-05-07 23:33:49 +04:00
|
|
|
opal_carto_base_free_graph(graph);
|
2008-01-23 12:20:34 +03:00
|
|
|
return -1;
|
|
|
|
}
|
2008-05-07 23:33:49 +04:00
|
|
|
distance = opal_carto_base_spf(graph, slot0, end_node);
|
2008-01-23 12:20:34 +03:00
|
|
|
opal_output(0,"\nThe distance between slot0 and mthca1 is %d\n",distance);
|
|
|
|
distance_array = OBJ_NEW(opal_value_array_t);
|
|
|
|
opal_value_array_init(distance_array, sizeof(opal_carto_node_distance_t));
|
|
|
|
opal_value_array_reserve(distance_array, 50);
|
2008-05-07 23:33:49 +04:00
|
|
|
distance_array_size = opal_carto_base_get_nodes_distance(graph, slot0, "Infiniband", distance_array);
|
2008-01-23 12:20:34 +03:00
|
|
|
for (i=0; i < distance_array_size; i++) {
|
|
|
|
node_distance = opal_value_array_get_item(distance_array, i);
|
|
|
|
opal_output(0,"Node %s distance from slot0 is %d\n",node_distance->node->node_name, node_distance->node_distance);
|
|
|
|
}
|
|
|
|
OBJ_RELEASE(distance_array);
|
2008-05-07 23:33:49 +04:00
|
|
|
opal_carto_base_free_graph(graph);
|
2008-01-23 12:20:34 +03:00
|
|
|
/**
|
2015-06-24 06:59:57 +03:00
|
|
|
*
|
2008-01-23 12:20:34 +03:00
|
|
|
*/
|
|
|
|
|
|
|
|
opal_output(0," \n\nget_host_graph Ethernet\n");
|
2008-05-07 23:33:49 +04:00
|
|
|
opal_carto_base_get_host_graph(&graph,"Ethernet");
|
2008-01-23 12:20:34 +03:00
|
|
|
opal_graph_print(graph);
|
2008-05-07 23:33:49 +04:00
|
|
|
slot0 = opal_carto_base_find_node(graph, "slot0");
|
2008-01-23 12:20:34 +03:00
|
|
|
if (NULL == slot0) {
|
|
|
|
opal_output(0,"couldnt find slot0 in the graph exiting\n");
|
2008-05-07 23:33:49 +04:00
|
|
|
opal_carto_base_free_graph(graph);
|
2008-01-23 12:20:34 +03:00
|
|
|
return -1;
|
|
|
|
}
|
2008-05-07 23:33:49 +04:00
|
|
|
end_node = opal_carto_base_find_node(graph, "eth1");
|
2008-01-23 12:20:34 +03:00
|
|
|
if (NULL == end_node) {
|
|
|
|
opal_output(0,"couldnt find mthca1 in the graph exiting\n");
|
2008-05-07 23:33:49 +04:00
|
|
|
opal_carto_base_free_graph(graph);
|
2008-01-23 12:20:34 +03:00
|
|
|
return -1;
|
|
|
|
}
|
2008-05-07 23:33:49 +04:00
|
|
|
distance = opal_carto_base_spf(graph, slot0, end_node);
|
2008-01-23 12:20:34 +03:00
|
|
|
opal_output(0,"\nThe distance between slot0 and eth1 is %d\n",distance);
|
|
|
|
distance_array = OBJ_NEW(opal_value_array_t);
|
|
|
|
opal_value_array_init(distance_array, sizeof(opal_carto_node_distance_t));
|
|
|
|
opal_value_array_reserve(distance_array, 50);
|
2008-05-07 23:33:49 +04:00
|
|
|
distance_array_size = opal_carto_base_get_nodes_distance(graph, slot0, "Ethernet", distance_array);
|
2008-01-23 12:20:34 +03:00
|
|
|
for (i=0; i < distance_array_size; i++) {
|
|
|
|
node_distance = opal_value_array_get_item(distance_array, i);
|
|
|
|
opal_output(0,"Node %s distance from slot0 is %d\n",node_distance->node->node_name, node_distance->node_distance);
|
|
|
|
}
|
|
|
|
OBJ_RELEASE(distance_array);
|
2008-05-07 23:33:49 +04:00
|
|
|
opal_carto_base_free_graph(graph);
|
2008-01-23 12:20:34 +03:00
|
|
|
/**
|
2015-06-24 06:59:57 +03:00
|
|
|
*
|
2008-01-23 12:20:34 +03:00
|
|
|
*/
|
|
|
|
|
|
|
|
opal_output(0," \n\nget_host_graph Memory\n");
|
2008-05-07 23:33:49 +04:00
|
|
|
opal_carto_base_get_host_graph(&graph,"Memory");
|
2008-01-23 12:20:34 +03:00
|
|
|
opal_graph_print(graph);
|
2008-05-07 23:33:49 +04:00
|
|
|
slot0 = opal_carto_base_find_node(graph, "slot0");
|
2008-01-23 12:20:34 +03:00
|
|
|
if (NULL == slot0) {
|
|
|
|
opal_output(0,"couldnt find slot0 in the graph exiting\n");
|
2008-05-07 23:33:49 +04:00
|
|
|
opal_carto_base_free_graph(graph);
|
2008-01-23 12:20:34 +03:00
|
|
|
return -1;
|
|
|
|
}
|
2008-05-07 23:33:49 +04:00
|
|
|
end_node = opal_carto_base_find_node(graph, "mem3");
|
2008-01-23 12:20:34 +03:00
|
|
|
if (NULL == end_node) {
|
|
|
|
opal_output(0,"couldnt find mthca1 in the graph exiting\n");
|
2008-05-07 23:33:49 +04:00
|
|
|
opal_carto_base_free_graph(graph);
|
2008-01-23 12:20:34 +03:00
|
|
|
return -1;
|
|
|
|
}
|
2008-05-07 23:33:49 +04:00
|
|
|
distance = opal_carto_base_spf(graph, slot0, end_node);
|
2008-01-23 12:20:34 +03:00
|
|
|
opal_output(0,"\nThe distance between slot0 and mem3 is %d\n",distance);
|
|
|
|
distance_array = OBJ_NEW(opal_value_array_t);
|
|
|
|
opal_value_array_init(distance_array, sizeof(opal_carto_node_distance_t));
|
|
|
|
opal_value_array_reserve(distance_array, 50);
|
2008-05-07 23:33:49 +04:00
|
|
|
distance_array_size = opal_carto_base_get_nodes_distance(graph, slot0, "Memory", distance_array);
|
2008-01-23 12:20:34 +03:00
|
|
|
for (i=0; i < distance_array_size; i++) {
|
|
|
|
node_distance = opal_value_array_get_item(distance_array, i);
|
|
|
|
opal_output(0,"Node %s distance from slot0 is %d\n",node_distance->node->node_name, node_distance->node_distance);
|
|
|
|
}
|
|
|
|
OBJ_RELEASE(distance_array);
|
2008-05-07 23:33:49 +04:00
|
|
|
opal_carto_base_free_graph(graph);
|
2008-01-23 12:20:34 +03:00
|
|
|
|
|
|
|
}
|
|
|
|
MPI_Barrier(MPI_COMM_WORLD);
|
|
|
|
MPI_Finalize();
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
}
|
2008-02-05 22:29:16 +03:00
|
|
|
|