X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/7d4a9a7e27436e76b10c1b1f9ce794655dc070a2..1fad5cf547a36c6e8868b1b4988893d183a9ca59:/src/smpi/smpi_global.c diff --git a/src/smpi/smpi_global.c b/src/smpi/smpi_global.c index 572cddae18..c547decdad 100644 --- a/src/smpi/smpi_global.c +++ b/src/smpi/smpi_global.c @@ -272,6 +272,7 @@ void smpi_global_destroy(void) smpi_comm_destroy(MPI_COMM_WORLD); MPI_COMM_WORLD = MPI_COMM_NULL; for (i = 0; i < count; i++) { + smpi_group_destroy(smpi_comm_group(process_data[i]->comm_self)); smpi_comm_destroy(process_data[i]->comm_self); xbt_os_timer_free(process_data[i]->timer); simcall_rdv_destroy(process_data[i]->mailbox); @@ -289,11 +290,12 @@ void smpi_global_destroy(void) /* With smpiff, the following weak symbols are replaced by those in libf2c */ int __attribute__((weak)) xargc; char** __attribute__((weak)) xargv; + +#ifndef WIN32 void __attribute__((weak)) user_main__(){ xbt_die("Should not be in this smpi_simulated_main"); return; } - int __attribute__((weak)) smpi_simulated_main__(int argc, char** argv) { smpi_process_init(&argc, &argv); user_main__(); @@ -308,6 +310,7 @@ int __attribute__((weak)) main(int argc, char** argv) { int __attribute__((weak)) MAIN__(){ return smpi_main(smpi_simulated_main__,xargc, xargv); }; +#endif int smpi_main(int (*realmain) (int argc, char *argv[]),int argc, char *argv[]) { @@ -319,8 +322,13 @@ int smpi_main(int (*realmain) (int argc, char *argv[]),int argc, char *argv[]) } /* Connect log categories. See xbt/log.c */ - XBT_LOG_CONNECT(smpi); /* Keep this line as soon as possible in this function: xbt_log_appender_file.c depends on it - DO NOT connect this in XBT or so, or it will be useless to xbt_log_appender_file.c */ + XBT_LOG_CONNECT(smpi); /* Keep this line as soon as possible in this + function: xbt_log_appender_file.c depends on it + DO NOT connect this in XBT or so, or it will be + useless to xbt_log_appender_file.c */ +#ifdef HAVE_TRACING + XBT_LOG_CONNECT(instr_smpi); +#endif XBT_LOG_CONNECT(smpi_base); XBT_LOG_CONNECT(smpi_bench); XBT_LOG_CONNECT(smpi_coll); @@ -331,9 +339,13 @@ int smpi_main(int (*realmain) (int argc, char *argv[]),int argc, char *argv[]) XBT_LOG_CONNECT(smpi_mpi_dt); XBT_LOG_CONNECT(smpi_pmpi); XBT_LOG_CONNECT(smpi_replay); + XBT_LOG_CONNECT(smpi_colls); #ifdef HAVE_TRACING TRACE_global_init(&argc, argv); + + TRACE_add_start_function(TRACE_smpi_alloc); + TRACE_add_end_function(TRACE_smpi_release); #endif SIMIX_global_init(&argc, argv);