From 184a6ba4c5f76feb3cdf2e0f16289069c9d13fcf Mon Sep 17 00:00:00 2001 From: Matthias Hochsteger Date: Thu, 16 May 2024 09:35:58 +0200 Subject: [PATCH] Fix MPI code in paje trace --- libsrc/core/paje_trace.cpp | 35 ++++++++++++++++++----------------- 1 file changed, 18 insertions(+), 17 deletions(-) diff --git a/libsrc/core/paje_trace.cpp b/libsrc/core/paje_trace.cpp index f97611a1..c8f37383 100644 --- a/libsrc/core/paje_trace.cpp +++ b/libsrc/core/paje_trace.cpp @@ -117,8 +117,11 @@ namespace ngcore for(auto i : IntRange(n_memory_events_at_start, memory_events.size())) memory_events[i].time -= start_time; - NgMPI_Comm comm(NG_MPI_COMM_WORLD); - + NgMPI_Comm comm; + #ifdef PARALLEL + if(MPI_Loaded()) + comm = NgMPI_Comm(NG_MPI_COMM_WORLD); + #endif if(comm.Size()==1) { Write(tracefile_name); @@ -491,14 +494,15 @@ namespace ngcore std::vector thread_aliases; std::vector container_nodes; -#ifdef PARALLEL - // Hostnames - NgMPI_Comm comm(NG_MPI_COMM_WORLD); - // auto rank = comm.Rank(); - auto nranks = comm.Size(); - if(nranks>1) + NgMPI_Comm comm; + #ifdef PARALLEL + if(MPI_Loaded()) + comm = NgMPI_Comm(NG_MPI_COMM_WORLD); + #endif + if(comm.Size()>1) { - nthreads = nranks; + auto comm = NgMPI_Comm(NG_MPI_COMM_WORLD); + nthreads = comm.Size(); thread_aliases.reserve(nthreads); std::array ahostname; @@ -509,7 +513,7 @@ namespace ngcore std::map host_map; std::string name; - for(auto i : IntRange(0, nranks)) + for(auto i : IntRange(0, comm.Size())) { if(i!=MPI_PAJE_WRITER) comm.Recv(name, i, 0); @@ -524,7 +528,6 @@ namespace ngcore } } else -#endif // PARALLEL { container_nodes.reserve(num_nodes); for(int i=0; i1) + if(comm.Size()>1) { - for(auto src : IntRange(0, nranks)) + for(auto src : IntRange(0, comm.Size())) { if(src==MPI_PAJE_WRITER) continue; @@ -622,7 +624,6 @@ namespace ngcore } } } -#endif // PARALLEL for(auto id : timer_ids) timer_aliases[id] = paje.DefineEntityValue( state_type_timer, timer_names[id], -1 ); @@ -747,7 +748,7 @@ namespace ngcore } #ifdef PARALLEL - if(nranks>1) + if(comm.Size()>1) { for(auto & event : timer_events) { @@ -763,7 +764,7 @@ namespace ngcore Array is_start; Array thread_id; - for(auto src : IntRange(0, nranks)) + for(auto src : IntRange(0, comm.Size())) { if(src==MPI_PAJE_WRITER) continue;