X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/56651d7c6d0cc1c2108ca0d8de7e34462acd0514..49e2303ab8fb6ac8f8f7a0fbbaa73528256396a7:/src/smpi/internals/smpi_bench.cpp diff --git a/src/smpi/internals/smpi_bench.cpp b/src/smpi/internals/smpi_bench.cpp index c28f90a63c..0c2d89b60e 100644 --- a/src/smpi/internals/smpi_bench.cpp +++ b/src/smpi/internals/smpi_bench.cpp @@ -20,6 +20,7 @@ #ifndef WIN32 #include #endif +#include #include #if HAVE_PAPI @@ -66,7 +67,7 @@ void smpi_execute(double duration) void smpi_execute_benched(double duration) { smpi_bench_end(); - double speed = sg_host_speed(sg_host_self()); + double speed = sg_host_get_speed(sg_host_self()); smpi_execute_flops(duration*speed); smpi_bench_begin(); } @@ -103,7 +104,7 @@ void smpi_bench_begin() double smpi_adjust_comp_speed(){ double speedup=1; if (smpi_cfg_comp_adjustment_file()[0] != '\0') { - smpi_trace_call_location_t* loc = smpi_process()->call_location(); + const smpi_trace_call_location_t* loc = smpi_process()->call_location(); std::string key = loc->get_composed_key(); std::unordered_map::const_iterator it = location2speedup.find(key); if (it != location2speedup.end()) { @@ -129,7 +130,7 @@ void smpi_bench_end() if (not smpi_cfg_papi_events_file().empty()) { papi_counter_t& counter_data = smpi_process()->papi_counters(); int event_set = smpi_process()->papi_event_set(); - std::vector event_values = std::vector(counter_data.size()); + std::vector event_values(counter_data.size()); if (PAPI_stop(event_set, &event_values[0]) != PAPI_OK) { // Error XBT_CRITICAL("Could not stop PAPI counters.\n"); @@ -144,7 +145,7 @@ void smpi_bench_end() if (smpi_process()->sampling()) { XBT_CRITICAL("Cannot do recursive benchmarks."); - XBT_CRITICAL("Are you trying to make a call to MPI within a SMPI_SAMPLE_ block?"); + XBT_CRITICAL("Are you trying to make a call to MPI within an SMPI_SAMPLE_ block?"); xbt_backtrace_display_current(); xbt_die("Aborting."); } @@ -162,7 +163,7 @@ void smpi_bench_end() const papi_counter_t& counter_data = smpi_process()->papi_counters(); for (auto const& pair : counter_data) { - simgrid::instr::VariableType* variable = static_cast(container->type_->by_name(pair.first)); + auto* variable = static_cast(container->type_->by_name(pair.first)); variable->set_event(SIMIX_get_clock(), pair.second); } } @@ -235,15 +236,17 @@ int smpi_gettimeofday(struct timeval* tv, struct timezone* tz) #if _POSIX_TIMERS > 0 int smpi_clock_gettime(clockid_t clk_id, struct timespec* tp) { + if (not tp) { + errno = EFAULT; + return -1; + } if (not smpi_process()) return clock_gettime(clk_id, tp); //there is only one time in SMPI, so clk_id is ignored. smpi_bench_end(); double now = SIMIX_get_clock(); - if (tp) { - tp->tv_sec = static_cast(now); - tp->tv_nsec = static_cast((now - tp->tv_sec) * 1e9); - } + tp->tv_sec = static_cast(now); + tp->tv_nsec = static_cast((now - tp->tv_sec) * 1e9); if (smpi_wtime_sleep > 0) simgrid::s4u::this_actor::sleep_for(smpi_wtime_sleep); smpi_bench_begin(); @@ -280,10 +283,10 @@ unsigned long long smpi_rastro_timestamp () smpi_bench_end(); double now = SIMIX_get_clock(); - unsigned long long sec = static_cast(now); + auto sec = static_cast(now); unsigned long long pre = (now - sec) * smpi_rastro_resolution(); smpi_bench_begin(); - return static_cast(sec) * smpi_rastro_resolution() + pre; + return sec * smpi_rastro_resolution() + pre; } /* ****************************** Functions related to the SMPI_SAMPLE_ macros ************************************/