X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/41058fa2ad8d53bfb3dfcbbb286665cd52f3cf62..62da5664b681577c99a3b0f51d8395876e7ecdf5:/teshsuite/simdag/platforms/flatifier.c diff --git a/teshsuite/simdag/platforms/flatifier.c b/teshsuite/simdag/platforms/flatifier.c index eac56b11fc..90c7cc3bb0 100644 --- a/teshsuite/simdag/platforms/flatifier.c +++ b/teshsuite/simdag/platforms/flatifier.c @@ -50,9 +50,10 @@ 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; + char **value; xbt_ex_t e; const SD_workstation_t *hosts; @@ -96,9 +97,9 @@ 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) + xbt_lib_foreach(as_router_lib, cursor_src, key, value) { + if(((network_element_info_t)xbt_lib_get_or_null(as_router_lib, key, + ROUTING_ASR_LEVEL))->rc_type == SURF_NETWORK_ELEMENT_ROUTER) { printf(" \n",key); } @@ -107,6 +108,7 @@ int main(int argc, char **argv) // 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,21 +125,51 @@ 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, value) // 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) + xbt_lib_foreach(host_lib, cursor_dst, dst, value) //to host + { + printf(" \n " + ,src + ,dst); + xbt_dynar_t route = global_routing->get_route(src,dst); + for(i=0;iname); + printf("",link_name); + free(link_name); + } + printf("\n \n"); + } + xbt_lib_foreach(as_router_lib, cursor_dst, dst, value) //to router + { + if(get_network_element_type(dst) == SURF_NETWORK_ELEMENT_ROUTER){ + printf(" \n " + ,src + ,dst); + xbt_dynar_t route = global_routing->get_route(src,dst); + for(i=0;iname); + printf("",link_name); + free(link_name); + } + printf("\n \n"); + } + } + } + + xbt_lib_foreach(as_router_lib, cursor_src, src, value) // Routes from router + { + if(get_network_element_type(src) == SURF_NETWORK_ELEMENT_ROUTER){ + xbt_lib_foreach(as_router_lib, cursor_dst, dst, value) //to router { - 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) - { + if(get_network_element_type(dst) == SURF_NETWORK_ELEMENT_ROUTER){ printf(" \n " ,src ,dst); @@ -148,10 +180,26 @@ int main(int argc, char **argv) char *link_name = bprintf("%s",((surf_resource_t) link)->name); printf("",link_name); + free(link_name); } printf("\n \n"); + } + } + xbt_lib_foreach(host_lib, cursor_dst, dst, value) //to host + { + printf(" \n " + ,src + ,dst); + xbt_dynar_t route = global_routing->get_route(src,dst); + for(i=0;iname); + printf("",link_name); + free(link_name); + } + printf("\n \n"); } } }