X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/6ee7e9c2e455536ab817ae0136acfbb53822eecd..87b29dcfb2c7d0b3b6df20a2cc055efa1f4b4be3:/teshsuite/simdag/platforms/flatifier.c diff --git a/teshsuite/simdag/platforms/flatifier.c b/teshsuite/simdag/platforms/flatifier.c index 72dedac4b6..c2e576d7cf 100644 --- a/teshsuite/simdag/platforms/flatifier.c +++ b/teshsuite/simdag/platforms/flatifier.c @@ -50,22 +50,27 @@ int main(int argc, char **argv) unsigned int i; xbt_dict_t props = NULL; xbt_dict_cursor_t cursor = NULL; - xbt_dict_cursor_t cursor_src = NULL; - xbt_dict_cursor_t cursor_dst = NULL; + xbt_lib_cursor_t cursor_src = NULL; + xbt_lib_cursor_t cursor_dst = NULL; char *src,*dst,*key,*data; + sg_routing_edge_t value1; + sg_routing_edge_t value2; xbt_ex_t e; const SD_workstation_t *hosts; const SD_link_t *links; + setvbuf(stdout, NULL, _IOLBF, 0); + SD_init(&argc, argv); platformFile = argv[1]; XBT_DEBUG("%s", platformFile); TRY { SD_create_environment(platformFile); - } CATCH(e) { - xbt_die(bprintf("Error while loading %s: %s",platformFile,e.msg)); + } + CATCH(e) { + xbt_die("Error while loading %s: %s",platformFile,e.msg); } printf("\n"); @@ -84,7 +89,7 @@ int main(int argc, char **argv) SD_workstation_get_name(hosts[i]), SD_workstation_get_power(hosts[i])); props = SD_workstation_get_properties(hosts[i]); - if (xbt_dict_length(props) > 0) { + if (props && !xbt_dict_is_empty(props)) { printf(">\n"); xbt_dict_foreach(props, cursor, key, data) { printf(" \n", key, data); @@ -96,17 +101,18 @@ int main(int argc, char **argv) } // Routers - xbt_dict_foreach(global_routing->where_network_elements, cursor, key, data) { - if(((network_element_info_t)xbt_dict_get(global_routing->where_network_elements, key))->rc_type - == SURF_NETWORK_ELEMENT_ROUTER) - { - printf(" \n",key); - } + xbt_lib_foreach(as_router_lib, cursor_src, key, value1) { + if(((sg_routing_edge_t)xbt_lib_get_or_null(as_router_lib, key, + ROUTING_ASR_LEVEL))->rc_type == SURF_NETWORK_ELEMENT_ROUTER) + { + printf(" \n",key); + } } // Links totalLinks = SD_link_get_number(); links = SD_link_get_list(); + qsort((void *) links, totalLinks, sizeof(SD_link_t), name_compare_links); for (i = 0; i < totalLinks; i++) { @@ -123,37 +129,92 @@ int main(int argc, char **argv) } } - // Routes - xbt_dict_foreach(global_routing->where_network_elements, cursor_src, src, data) + + xbt_lib_foreach(host_lib, cursor_src, src, value1) // Routes from host { - if(((network_element_info_t)xbt_dict_get(global_routing->where_network_elements, src))->rc_type - == SURF_NETWORK_ELEMENT_ROUTER || - ((network_element_info_t)xbt_dict_get(global_routing->where_network_elements, src))->rc_type - == SURF_NETWORK_ELEMENT_HOST) - { - xbt_dict_foreach(global_routing->where_network_elements, cursor_dst, dst, data) - { - if(((network_element_info_t)xbt_dict_get(global_routing->where_network_elements, dst))->rc_type - == SURF_NETWORK_ELEMENT_ROUTER || - ((network_element_info_t)xbt_dict_get(global_routing->where_network_elements, dst))->rc_type - == SURF_NETWORK_ELEMENT_HOST) - { - printf(" \n " - ,src - ,dst); - xbt_dynar_t route = global_routing->get_route(src,dst); - for(i=0;iname); - printf("",link_name); - } - printf("\n \n"); - - } - } - } + value1 = xbt_lib_get_or_null(host_lib,src,ROUTING_HOST_LEVEL); + xbt_lib_foreach(host_lib, cursor_dst, dst, value2) //to host + { + printf(" \n " + ,src + ,dst); + xbt_dynar_t route=NULL; + value2 = xbt_lib_get_or_null(host_lib,dst,ROUTING_HOST_LEVEL); + routing_get_route_and_latency(value1,value2,&route,NULL); + for(i=0;iname); + printf("",link_name); + free(link_name); + } + printf("\n \n"); + } + xbt_lib_foreach(as_router_lib, cursor_dst, dst, value2) //to router + { + if(routing_get_network_element_type(dst) == SURF_NETWORK_ELEMENT_ROUTER){ + printf(" \n " + ,src + ,dst); + xbt_dynar_t route=NULL; + value2 = xbt_lib_get_or_null(as_router_lib,dst,ROUTING_ASR_LEVEL); + routing_get_route_and_latency((sg_routing_edge_t)value1,(sg_routing_edge_t)value2,&route,NULL); + for(i=0;iname); + printf("",link_name); + free(link_name); + } + printf("\n \n"); + } + } + } + + xbt_lib_foreach(as_router_lib, cursor_src, src, value1) // Routes from router + { + value1 = xbt_lib_get_or_null(as_router_lib,src,ROUTING_ASR_LEVEL); + if(routing_get_network_element_type(src) == SURF_NETWORK_ELEMENT_ROUTER){ + xbt_lib_foreach(as_router_lib, cursor_dst, dst, value2) //to router + { + if(routing_get_network_element_type(dst) == SURF_NETWORK_ELEMENT_ROUTER){ + printf(" \n " + ,src + ,dst); + xbt_dynar_t route=NULL; + value2 = xbt_lib_get_or_null(as_router_lib,dst,ROUTING_ASR_LEVEL); + routing_get_route_and_latency((sg_routing_edge_t)value1,(sg_routing_edge_t)value2,&route,NULL); + for(i=0;iname); + printf("",link_name); + free(link_name); + } + printf("\n \n"); + } + } + xbt_lib_foreach(host_lib, cursor_dst, dst, value2) //to host + { + printf(" \n " + ,src, dst); + xbt_dynar_t route=NULL; + value2 = xbt_lib_get_or_null(host_lib,dst,ROUTING_HOST_LEVEL); + routing_get_route_and_latency((sg_routing_edge_t)value1,(sg_routing_edge_t)value2,&route, NULL); + for(i=0;iname); + printf("",link_name); + free(link_name); + } + printf("\n \n"); + } + } } printf("\n");