X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/eadbe829389f23151f79257824f3164d7801bbc7..f6361035ba2972dede69bcdf16bc6724bd50bf7d:/src/simix/smx_global.cpp diff --git a/src/simix/smx_global.cpp b/src/simix/smx_global.cpp index b44d2c8648..bcca356024 100644 --- a/src/simix/smx_global.cpp +++ b/src/simix/smx_global.cpp @@ -192,10 +192,10 @@ void SIMIX_global_init(int *argc, char **argv) #endif if (simix_global == nullptr) { + surf_init(argc, argv); /* Initialize SURF structures */ + simix_global.reset(new simgrid::simix::Global()); simix_global->maestro_process = nullptr; - - surf_init(argc, argv); /* Initialize SURF structures */ SIMIX_context_mod_init(); // Either create a new context with maestro or create @@ -220,9 +220,6 @@ void SIMIX_global_init(int *argc, char **argv) if (simgrid::config::get_value("clean-atexit")) atexit(SIMIX_clean); - - if (_sg_cfg_exit_asap) - exit(0); } int smx_cleaned = 0; @@ -316,15 +313,15 @@ static void SIMIX_wake_processes() XBT_DEBUG("Handling the processes whose action failed (if any)"); while ((action = model->extract_failed_action())) { XBT_DEBUG(" Handling Action %p",action); - SIMIX_simcall_exit(static_cast(action->get_data())); + SIMIX_simcall_exit(action->get_activity()); } XBT_DEBUG("Handling the processes whose action terminated normally (if any)"); while ((action = model->extract_done_action())) { XBT_DEBUG(" Handling Action %p",action); - if (action->get_data() == nullptr) + if (action->get_activity() == nullptr) XBT_DEBUG("probably vcpu's action %p, skip", action); else - SIMIX_simcall_exit(static_cast(action->get_data())); + SIMIX_simcall_exit(action->get_activity()); } } } @@ -569,6 +566,11 @@ void SIMIX_display_process_status() if (process->waiting_synchro) { const char* synchro_description = "unknown"; + // we don't care about the Activity type to get its name, use RawImpl + const char* name = + boost::static_pointer_cast>( + process->waiting_synchro) + ->get_cname(); if (boost::dynamic_pointer_cast(process->waiting_synchro) != nullptr) synchro_description = "execution"; @@ -587,8 +589,7 @@ void SIMIX_display_process_status() XBT_INFO("Process %ld (%s@%s): waiting for %s synchro %p (%s) in state %d to finish", process->get_pid(), process->get_cname(), process->get_host()->get_cname(), synchro_description, - process->waiting_synchro.get(), process->waiting_synchro->get_cname(), - (int)process->waiting_synchro->state_); + process->waiting_synchro.get(), name, (int)process->waiting_synchro->state_); } else { XBT_INFO("Process %ld (%s@%s)", process->get_pid(), process->get_cname(), process->get_host()->get_cname());