X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/60a8ff5d9cd01ef8952498dbeda34441df6595b2..d47d157d7ca07e8253323fae04795fdbace9ae7c:/teshsuite/simdag/platforms/flatifier.c diff --git a/teshsuite/simdag/platforms/flatifier.c b/teshsuite/simdag/platforms/flatifier.c index dc4c3c8431..e0762b0f07 100644 --- a/teshsuite/simdag/platforms/flatifier.c +++ b/teshsuite/simdag/platforms/flatifier.c @@ -1,5 +1,10 @@ +/* Copyright (c) 2008-2014. The SimGrid Team. + * All rights reserved. */ -#ifndef WIN32 +/* This program is free software; you can redistribute it and/or modify it + * under the terms of the license (GNU LGPL) which comes with this package. */ + +#ifndef _XBT_WIN32 #include #endif @@ -13,109 +18,272 @@ #include "simdag/simdag.h" #include "xbt/log.h" #include "xbt/dict.h" +#include "xbt/ex.h" +#include "xbt/xbt_os_time.h" +#include "surf/surf.h" +#include "surf/surf_private.h" + +static const char link_ctn_v2[] = "link:ctn"; +static const char link_ctn_v3[] = "link_ctn"; -XBT_LOG_NEW_DEFAULT_CATEGORY(validator, - "Logging specific to this SimDag example"); +XBT_LOG_NEW_DEFAULT_CATEGORY(flatifier, + "Logging specific to this platform parsing tool"); static int name_compare_hosts(const void *n1, const void *n2) { char name1[80], name2[80]; - strcpy(name1, SD_workstation_get_name(*((SD_workstation_t *)n1))); - strcpy(name2, SD_workstation_get_name(*((SD_workstation_t *)n2))); + strcpy(name1, SD_workstation_get_name(*((SD_workstation_t *) n1))); + strcpy(name2, SD_workstation_get_name(*((SD_workstation_t *) n2))); - return strcmp(name1,name2); + return strcmp(name1, name2); } static int name_compare_links(const void *n1, const void *n2) { char name1[80], name2[80]; - strcpy(name1, SD_link_get_name(*((SD_link_t *)n1))); - strcpy(name2, SD_link_get_name(*((SD_link_t *)n2))); + strcpy(name1, SD_link_get_name(*((SD_link_t *) n1))); + strcpy(name2, SD_link_get_name(*((SD_link_t *) n2))); - return strcmp(name1,name2); + return strcmp(name1, name2); } -int main(int argc, char **argv) { - char *platformFile=NULL; - int totalHosts, totalLinks, tmp_length; - int i,j,k; +static int parse_cmdline(int *timings, int *downgrade, char **platformFile, int argc, char **argv) +{ + int wrong_option = 0; + int i; + for (i = 1; i < argc; i++) { + if (strlen(argv[i]) > 1 && argv[i][0] == '-' && argv[i][1] == '-') { + if (!strcmp(argv[i], "--timings")) { + *timings = 1; + } else { + if (!strcmp(argv[i], "--downgrade")) { + *downgrade = 1; + } else { + wrong_option = 1; + break; + } + } + } else { + *platformFile = argv[i]; + } + } + return wrong_option; +} + +static void create_environment(xbt_os_timer_t parse_time, const char *platformFile) +{ + xbt_ex_t e; + TRY { + xbt_os_cputimer_start(parse_time); + SD_create_environment(platformFile); + xbt_os_cputimer_stop(parse_time); + } + CATCH(e) { + xbt_die("Error while loading %s: %s", platformFile, e.msg); + } +} + +int main(int argc, char **argv) +{ + char *platformFile = NULL; + int totalHosts, totalLinks; + int timings=0; + int downgrade = 0; + int version = 3; + const char *link_ctn = link_ctn_v3; + unsigned int i; xbt_dict_t props = NULL; - xbt_dict_cursor_t cursor=NULL; - char *key,*data; + xbt_dict_cursor_t cursor = 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; const SD_workstation_t *hosts; - const SD_link_t *links, *tmp; + const SD_link_t *links; + xbt_os_timer_t parse_time = xbt_os_timer_new(); - SD_init(&argc, argv); +#ifdef _XBT_WIN32 + setbuf(stderr, NULL); + setbuf(stdout, NULL); +#else + setvbuf(stdout, NULL, _IOLBF, 0); +#endif - platformFile = argv[1]; - DEBUG1("%s",platformFile); - SD_create_environment(platformFile); + SD_init(&argc, argv); - printf ("\n"); - printf ("\n"); - printf ("\n"); + if (parse_cmdline(&timings, &downgrade, &platformFile, argc, argv) || !platformFile) { + xbt_die("Invalid command line arguments: expected [--timings|--downgrade] platformFile"); + } - totalHosts = SD_workstation_get_number(); - hosts = SD_workstation_get_list(); - qsort((void *)hosts, totalHosts, sizeof(SD_workstation_t), - name_compare_hosts); - - for (i=0;i0) { - printf(">\n"); - xbt_dict_foreach(props,cursor,key,data) { - printf(" \n",key,data); + XBT_DEBUG("%d,%d,%s", timings, downgrade, platformFile); + + if (downgrade) { + version = 2; + link_ctn = link_ctn_v2; + } + + create_environment(parse_time, platformFile); + + if (timings) { + XBT_INFO("Parsing time: %fs (%d hosts, %d links)", + xbt_os_timer_elapsed(parse_time),SD_workstation_get_number(),SD_link_get_number()); + } else { + printf("\n"); + printf("\n"); + printf("\n", version); + if (!downgrade) + printf("\n"); + + // Hosts + totalHosts = SD_workstation_get_number(); + hosts = SD_workstation_get_list(); + qsort((void *) hosts, totalHosts, sizeof(SD_workstation_t), + name_compare_hosts); + + for (i = 0; i < totalHosts; i++) { + printf(" 1) { + printf(" cores=\"%d\"", SD_workstation_get_cores(hosts[i])); + } + if (props && !xbt_dict_is_empty(props)) { + printf(">\n"); + xbt_dict_foreach(props, cursor, key, data) { + printf(" \n", key, data); + } + printf(" \n"); + } else { + printf("/>\n"); } - printf(" \n"); - } else { - printf("/>\n"); } - } - 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\n"); - } else { - printf(" sharing_policy=\"FATPIPE\"/>\n"); + // Routers + xbt_lib_foreach(as_router_lib, cursor_src, key, value1) { + if(surf_routing_edge_get_rc_type(xbt_lib_get_or_null(as_router_lib, key, + ROUTING_ASR_LEVEL)) == SURF_NETWORK_ELEMENT_ROUTER) + { + printf(" \n",key); + } } - } - for (i=0;i\n ", - SD_workstation_get_name(hosts[i]), - SD_workstation_get_name(hosts[j])); - - tmp_length = SD_route_get_size(hosts[i],hosts[j]); - for (k=0; k", SD_link_get_name(tmp[k])); - } - printf("\n \n"); + // 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++) { + printf(" \n"); + } else { + printf(" sharing_policy=\"FATPIPE\"/>\n"); } } + + + xbt_lib_foreach(host_lib, cursor_src, src, value1) // Routes from host + { + 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;i",link_ctn,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;i",link_ctn,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;i",link_ctn,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;i",link_ctn,link_name); + free(link_name); + } + printf("\n \n"); + } + } + } + + if (!downgrade) + printf("\n"); + printf("\n"); } - printf("\n"); SD_exit(); - + xbt_os_timer_free(parse_time); + return 0; } - -