Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Add a platform with a bypass route. Add the test to cmake.
[simgrid.git] / teshsuite / simdag / platforms / flatifier.c
index 86f2941..5695df8 100644 (file)
@@ -18,6 +18,9 @@
 #include "simdag/simdag.h"
 #include "xbt/log.h"
 #include "xbt/dict.h"
+#include "xbt/ex.h"
+#include "surf/surf.h"
+#include "surf/surf_private.h"
 
 XBT_LOG_NEW_DEFAULT_CATEGORY(validator,
                              "Logging specific to this SimDag example");
@@ -43,25 +46,38 @@ static int name_compare_links(const void *n1, const void *n2)
 int main(int argc, char **argv)
 {
   char *platformFile = NULL;
-  int totalHosts, totalLinks, tmp_length;
-  int i, j, k;
+  int totalHosts, totalLinks;
+  unsigned int i;
   xbt_dict_t props = NULL;
   xbt_dict_cursor_t cursor = NULL;
-  char *key, *data;
+  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;
-  const SD_link_t *links, *tmp;
+  const SD_link_t *links;
+
+  setvbuf(stdout, NULL, _IOLBF, 0);
 
   SD_init(&argc, argv);
 
   platformFile = argv[1];
-  DEBUG1("%s", platformFile);
-  SD_create_environment(platformFile);
+  XBT_DEBUG("%s", platformFile);
+  TRY {
+    SD_create_environment(platformFile);
+  }
+  CATCH(e) {
+    xbt_die("Error while loading %s: %s",platformFile,e.msg);
+  }
 
   printf("<?xml version='1.0'?>\n");
-  printf("<!DOCTYPE platform SYSTEM \"simgrid.dtd\">\n");
-  printf("<platform version=\"2\">\n");
+  printf("<!DOCTYPE platform SYSTEM \"http://simgrid.gforge.inria.fr/simgrid.dtd\">\n");
+  printf("<platform version=\"3\">\n");
+  printf("<AS id=\"AS0\" routing=\"Full\">\n");
 
+  // Hosts
   totalHosts = SD_workstation_get_number();
   hosts = SD_workstation_get_list();
   qsort((void *) hosts, totalHosts, sizeof(SD_workstation_t),
@@ -72,7 +88,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("    <prop id=\"%s\" value=\"%s\"/>\n", key, data);
@@ -83,8 +99,19 @@ int main(int argc, char **argv)
     }
   }
 
+  // Routers
+  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("  <router id=\"%s\"/>\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++) {
@@ -101,22 +128,89 @@ int main(int argc, char **argv)
     }
   }
 
-  for (i = 0; i < totalHosts; i++) {
-    for (j = 0; j < totalHosts; j++) {
-      tmp = SD_route_get_list(hosts[i], hosts[j]);
-      if (tmp) {
-        printf("  <route src=\"%s\" dst=\"%s\">\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 < tmp_length; k++) {
-          printf("<link:ctn id=\"%s\"/>", SD_link_get_name(tmp[k]));
-        }
-        printf("\n  </route>\n");
-      }
-    }
+
+  xbt_lib_foreach(host_lib, cursor_src, src, value) // Routes from host
+  {
+                 xbt_lib_foreach(host_lib, cursor_dst, dst, value) //to host
+                 {
+                               printf("  <route src=\"%s\" dst=\"%s\">\n  "
+                                         ,src
+                                         ,dst);
+                               xbt_dynar_t route=NULL;
+                               routing_get_route_and_latency(src,dst,&route,NULL);
+                               for(i=0;i<xbt_dynar_length(route) ;i++)
+                               {
+                                       void *link = xbt_dynar_get_as(route,i,void *);
+
+                                       char *link_name = xbt_strdup(((surf_resource_t)link)->name);
+                                       printf("<link_ctn id=\"%s\"/>",link_name);
+                                       free(link_name);
+                               }
+                               printf("\n  </route>\n");
+                 }
+                 xbt_lib_foreach(as_router_lib, cursor_dst, dst, value) //to router
+                 {
+                           if(routing_get_network_element_type(dst) == SURF_NETWORK_ELEMENT_ROUTER){
+                               printf("  <route src=\"%s\" dst=\"%s\">\n  "
+                                         ,src
+                                         ,dst);
+                               xbt_dynar_t route=NULL;
+                               routing_get_route_and_latency(src,dst,&route,NULL);
+                               for(i=0;i<xbt_dynar_length(route) ;i++)
+                               {
+                                       void *link = xbt_dynar_get_as(route,i,void *);
+
+                                       char *link_name = xbt_strdup(((surf_resource_t)link)->name);
+                                       printf("<link_ctn id=\"%s\"/>",link_name);
+                                       free(link_name);
+                               }
+                               printf("\n  </route>\n");
+                           }
+                 }
   }
+
+  xbt_lib_foreach(as_router_lib, cursor_src, src, value) // Routes from router
+  {
+         if(routing_get_network_element_type(src) == SURF_NETWORK_ELEMENT_ROUTER){
+                 xbt_lib_foreach(as_router_lib, cursor_dst, dst, value) //to router
+                 {
+                               if(routing_get_network_element_type(dst) == SURF_NETWORK_ELEMENT_ROUTER){
+                               printf("  <route src=\"%s\" dst=\"%s\">\n  "
+                                         ,src
+                                         ,dst);
+                               xbt_dynar_t route=NULL;
+                               routing_get_route_and_latency(src,dst,&route,NULL);
+                               for(i=0;i<xbt_dynar_length(route) ;i++)
+                               {
+                                       void *link = xbt_dynar_get_as(route,i,void *);
+
+                                       char *link_name = xbt_strdup(((surf_resource_t)link)->name);
+                                       printf("<link_ctn id=\"%s\"/>",link_name);
+                                       free(link_name);
+                               }
+                               printf("\n  </route>\n");
+                               }
+                 }
+                 xbt_lib_foreach(host_lib, cursor_dst, dst, value) //to host
+                 {
+                               printf("  <route src=\"%s\" dst=\"%s\">\n  "
+                                         ,src, dst);
+                               xbt_dynar_t route=NULL;
+                               routing_get_route_and_latency(src,dst,&route, NULL);
+                               for(i=0;i<xbt_dynar_length(route) ;i++)
+                               {
+                                       void *link = xbt_dynar_get_as(route,i,void *);
+
+                                       char *link_name = xbt_strdup(((surf_resource_t)link)->name);
+                                       printf("<link_ctn id=\"%s\"/>",link_name);
+                                       free(link_name);
+                               }
+                               printf("\n  </route>\n");
+                 }
+         }
+  }
+
+  printf("</AS>\n");
   printf("</platform>\n");
   SD_exit();