X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/4c326c3ead872860a1ee05f216174ba56cae6e71..f00304f35fc10b4c8d3cdb6c2d910131c4169ef9:/teshsuite/simdag/platforms/basic_parsing_test.c diff --git a/teshsuite/simdag/platforms/basic_parsing_test.c b/teshsuite/simdag/platforms/basic_parsing_test.c index afce3b9b70..ecd1df8ca9 100644 --- a/teshsuite/simdag/platforms/basic_parsing_test.c +++ b/teshsuite/simdag/platforms/basic_parsing_test.c @@ -11,14 +11,76 @@ int main(int argc, char **argv) { /* initialisation of SD */ + + SD_workstation_t w1, w2; + const SD_workstation_t *workstations; + const SD_link_t *route; + const char *name1; + const char *name2; + int route_size,i,j,k; + int list_size; + SD_init(&argc, argv); /* creation of the environment */ SD_create_environment(argv[1]); - - printf("\n\nWorkstation number: %d, link number: %d\n\n", + printf("Workstation number: %d, link number: %d\n", SD_workstation_get_number(), SD_link_get_number()); +if(argc == 3) +{ + if(!strcmp(argv[2],"ONE_LINK")) + { + workstations = SD_workstation_get_list(); + w1 = workstations[0]; + w2 = workstations[1]; + name1 = SD_workstation_get_name(w1); + name2 = SD_workstation_get_name(w2); + + printf("Route between %s and %s\n", name1, name2); + route = SD_route_get_list(w1, w2); + route_size = SD_route_get_size(w1, w2); + printf("Route size %d\n", route_size); + for (i = 0; i < route_size; i++) { + printf(" Link %s: latency = %f, bandwidth = %f\n", + SD_link_get_name(route[i]), SD_link_get_current_latency(route[i]), + SD_link_get_current_bandwidth(route[i])); + } + printf("Route latency = %f, route bandwidth = %f\n", + SD_route_get_current_latency(w1, w2), + SD_route_get_current_bandwidth(w1, w2)); + } + if(!strcmp(argv[2],"FULL_LINK")) + { + workstations = SD_workstation_get_list(); + list_size = SD_workstation_get_number(); + for(i = 0; i < list_size; i++) + { + for(j = 0 ; j < list_size; j++) + { + w1 = workstations[i]; + w2 = workstations[j]; + name1 = SD_workstation_get_name(w1); + name2 = SD_workstation_get_name(w2); + printf("Route between %s and %s\n", name1, name2); + route = SD_route_get_list(w1, w2); + route_size = SD_route_get_size(w1, w2); + printf("\tRoute size %d\n", route_size); + for (k = 0; k < route_size; k++) { + printf("\tLink %s: latency = %f, bandwidth = %f\n", + SD_link_get_name(route[k]), SD_link_get_current_latency(route[k]), + SD_link_get_current_bandwidth(route[k])); + } + printf("\tRoute latency = %f, route bandwidth = %f\n", + SD_route_get_current_latency(w1, w2), + SD_route_get_current_bandwidth(w1, w2)); + } + } + + } + +} + SD_exit(); return 0; }