Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
cleanups in teshsuite/simdag/platforms, don't ask why
[simgrid.git] / teshsuite / simdag / platforms / Evaluate_parse_time.c
index 11ffd3d..e3c46a1 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (c) 2008, 2009, 2010. The SimGrid Team.
+/* Copyright (c) 2008-2015. The SimGrid Team.
  * All rights reserved.                                                     */
 
 /* This program is free software; you can redistribute it and/or modify it
@@ -8,43 +8,30 @@
 
 #include <stdio.h>
 #include <stdlib.h>
-#include "simdag/simdag.h"
-#include "surf/surf_private.h"
-#include <time.h>
-
-#define BILLION  1000000000L;
-extern routing_global_t global_routing;
+#include "simgrid/simdag.h"
+#include "surf/surf.h"
+#include "xbt/xbt_os_time.h"
 
 int main(int argc, char **argv)
 {
-       struct timespec start, stop;
-       double accum;
-
-       /* initialisation of SD */
-       SD_init(&argc, argv);
-
-       if( clock_gettime( CLOCK_REALTIME, &start) == -1 ) {
-       perror( "clock gettime" );
-       return EXIT_FAILURE;
-       }
-
-       /* creation of the environment */
-       SD_create_environment(argv[1]);
-
-       if( clock_gettime( CLOCK_REALTIME, &stop) == -1 ) {
-       perror( "clock gettime" );
-       return EXIT_FAILURE;
-       }
-
-       accum = ( stop.tv_sec - start.tv_sec )
-                  + (double)( stop.tv_nsec - start.tv_nsec )
-                        / (double)BILLION;
-
-       printf( "%lf\n", accum );
-
-       sleep(20);
-
-       SD_exit();
-
-       return 0;
+  xbt_os_timer_t timer = xbt_os_timer_new();
+  SD_init(&argc, argv);
+
+  /* creation of the environment, timed */
+  xbt_os_cputimer_start(timer);
+  SD_create_environment(argv[1]);
+  xbt_os_cputimer_stop(timer);
+
+  /* Display the result and exit after cleanup */
+  printf( "%f\n", xbt_os_timer_elapsed(timer) );
+  printf("Workstation number: %zu, link number: %d\n", sg_host_count(), sg_link_count());
+  if(argv[2]){
+    printf("Wait for %ss\n",argv[2]);
+    sleep(atoi(argv[2]));
+  }
+
+  SD_exit();
+
+  free(timer);
+  return 0;
 }