X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/61270581ab9406eb95fc6279c41201b1bd853a8d..efb48157b629f9950a06c8987c9a41cd354bb979:/src/smpi/smpi_bench.c diff --git a/src/smpi/smpi_bench.c b/src/smpi/smpi_bench.c index f2a5feff80..ca628b9f22 100644 --- a/src/smpi/smpi_bench.c +++ b/src/smpi/smpi_bench.c @@ -4,18 +4,21 @@ /* 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. */ -#include // sqrt #include "private.h" #include "xbt/dict.h" #include "xbt/sysdep.h" #include "xbt/ex.h" #include "surf/surf.h" +#include "simgrid/sg_config.h" +#ifndef WIN32 #include +#endif #include #include #include #include +#include // sqrt #include #include #include @@ -82,6 +85,7 @@ static size_t shm_size(int fd) { return (size_t)st.st_size; } +#ifndef WIN32 static void* shm_map(int fd, size_t size, shared_data_t* data) { void* mem; char loc[PTR_STRLEN]; @@ -92,6 +96,7 @@ static void* shm_map(int fd, size_t size, shared_data_t* data) { xbt_die("Could not truncate fd %d to %zu: %s", fd, size, strerror(errno)); } } + mem = mmap(NULL, size, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0); if(mem == MAP_FAILED) { xbt_die("Could not map fd %d: %s", fd, strerror(errno)); @@ -107,6 +112,7 @@ static void* shm_map(int fd, size_t size, shared_data_t* data) { XBT_DEBUG("MMAP %zu to %p", size, mem); return mem; } +#endif void smpi_bench_destroy(void) { @@ -131,14 +137,13 @@ void smpi_execute_flops(double flops) { static void smpi_execute(double duration) { /* FIXME: a global variable would be less expensive to consult than a call to xbt_cfg_get_double() right on the critical path */ - if (duration >= xbt_cfg_get_double(_surf_cfg_set, "smpi/cpu_threshold")) { + if (duration >= sg_cfg_get_double("smpi/cpu_threshold")) { XBT_DEBUG("Sleep for %f to handle real computation time", duration); smpi_execute_flops(duration * - xbt_cfg_get_double(_surf_cfg_set, - "smpi/running_power")); + sg_cfg_get_double("smpi/running_power")); } else { XBT_DEBUG("Real computation took %f while option smpi/cpu_threshold is set to %f => ignore it", - duration, xbt_cfg_get_double(_surf_cfg_set, "smpi/cpu_threshold")); + duration, sg_cfg_get_double("smpi/cpu_threshold")); } } @@ -164,14 +169,18 @@ unsigned int smpi_sleep(unsigned int secs) return secs; } -int smpi_gettimeofday(struct timeval *tv, struct timezone *tz) +int smpi_gettimeofday(struct timeval *tv) { double now; smpi_bench_end(); now = SIMIX_get_clock(); if (tv) { tv->tv_sec = (time_t)now; +#ifdef WIN32 + tv->tv_usec = (useconds_t)((now - tv->tv_sec) * 1e6); +#else tv->tv_usec = (suseconds_t)((now - tv->tv_sec) * 1e6); +#endif } smpi_bench_begin(); return 0; @@ -217,8 +226,13 @@ static char *sample_location(int global, const char *file, int line) { } } static int sample_enough_benchs(local_data_t *data) { - int res = (data->iters > 0 && data->count >= data->iters) - || (data->count > 2 && data->threshold > 0.0 && data->relstderr <= data->threshold); + int res = data->count >= data->iters; + if (data->threshold>0.0) { + if (data->count <2) + res = 0; // not enough data + if (data->relstderr > data->threshold) + res = 0; // stderr too high yet + } XBT_DEBUG("%s (count:%d iter:%d stderr:%f thres:%f mean:%fs)", (res?"enough benchs":"need more data"), data->count, data->iters, data->relstderr, data->threshold, data->mean); @@ -236,6 +250,8 @@ void smpi_sample_1(int global, const char *file, int line, int iters, double thr data = xbt_dict_get_or_null(samples, loc); if (!data) { + xbt_assert(threshold>0 || iters>0, + "You should provide either a positive amount of iterations to bench, or a positive maximal stderr (or both)"); data = (local_data_t *) xbt_new(local_data_t, 1); data->count = 0; data->sum = 0.0; @@ -324,6 +340,7 @@ void smpi_sample_3(int global, const char *file, int line) data->benching = 0; } +#ifndef WIN32 void *smpi_shared_malloc(size_t size, const char *file, int line) { char *loc = bprintf("%zu_%s_%d", (size_t)getpid(), file, line); @@ -370,7 +387,6 @@ void *smpi_shared_malloc(size_t size, const char *file, int line) XBT_DEBUG("Malloc %zu in %p (metadata at %p)", size, mem, data); return mem; } - void smpi_shared_free(void *ptr) { char loc[PTR_STRLEN]; @@ -405,6 +421,7 @@ void smpi_shared_free(void *ptr) free(data->loc); } } +#endif int smpi_shared_known_call(const char* func, const char* input) { char* loc = bprintf("%s:%s", func, input);