X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/fb58fcc2c0b069aa815f1820acfa16a46720ae93..0c14e681436e252f680310c7696b3ba17a349706:/src/simix/smx_process.c diff --git a/src/simix/smx_process.c b/src/simix/smx_process.c index 44943d9176..31d822a8c4 100644 --- a/src/simix/smx_process.c +++ b/src/simix/smx_process.c @@ -156,6 +156,7 @@ smx_process_t SIMIX_process_create_from_wrapper(smx_process_arg_t args) { args->code, args->data, args->hostname, + args->kill_time, args->argc, args->argv, args->properties); @@ -177,6 +178,7 @@ void SIMIX_process_create(smx_process_t *process, xbt_main_func_t code, void *data, const char *hostname, + double kill_time, int argc, char **argv, xbt_dict_t properties) { @@ -222,6 +224,14 @@ void SIMIX_process_create(smx_process_t *process, XBT_DEBUG("Inserting %s(%s) in the to_run list", (*process)->name, host->name); xbt_dynar_push_as(simix_global->process_to_run, smx_process_t, *process); } + + if (kill_time > SIMIX_get_clock()) { + if (simix_global->kill_process_function) { + XBT_DEBUG("Process %s(%s) will be kill at time %f", (*process)->name, + (*process)->smx_host->name, kill_time); + SIMIX_timer_set(kill_time, simix_global->kill_process_function, *process); + } + } } /** @@ -374,13 +384,17 @@ smx_action_t SIMIX_process_suspend(smx_process_t process, smx_process_t issuer) SIMIX_process_sleep_suspend(process->waiting_action); break; + case SIMIX_ACTION_SYNCHRO: + /* Suspension is delayed to when the process is rescheduled. */ + break; + default: xbt_die("Internal error in SIMIX_process_suspend: unexpected action type %d", (int)process->waiting_action->type); } return NULL; } else { - DIE_IMPOSSIBLE; + /* Suspension is delayed to when the process is rescheduled. */ return NULL; } } else { @@ -392,8 +406,13 @@ void SIMIX_process_resume(smx_process_t process, smx_process_t issuer) { xbt_assert((process != NULL), "Invalid parameters"); - if(process->context->iwannadie) return; - process->suspended = 0; + XBT_IN("process = %p, issuer = %p", process, issuer); + + if(process->context->iwannadie) + return; + + if(!process->suspended) return; + process->suspended = 0; /* If we are resuming another process, resume the action it was waiting for if any. Otherwise add it to the list of process to run in the next round. */ @@ -416,17 +435,19 @@ void SIMIX_process_resume(smx_process_t process, smx_process_t issuer) SIMIX_process_sleep_resume(process->waiting_action); break; + case SIMIX_ACTION_SYNCHRO: + /* I cannot resume it now. This is delayed to when the process is rescheduled at + * the end of the synchro. */ + break; + default: xbt_die("Internal error in SIMIX_process_resume: unexpected action type %d", (int)process->waiting_action->type); } } - else { - DIE_IMPOSSIBLE; -// if(!xbt_dynar_member(simix_global->process_to_run, &(process))) -// xbt_dynar_push_as(simix_global->process_to_run, smx_process_t, process); - } - } + } else XBT_WARN("Strange. Process %p is trying to resume himself.", issuer); + + XBT_OUT(); } int SIMIX_process_get_maxpid(void) { @@ -618,6 +639,12 @@ void SIMIX_process_yield(smx_process_t self) SIMIX_context_stop(self->context); } + if(self->suspended) { + xbt_assert(!self->doexception, "Gloups! This exception may be lost by subsequent calls."); + self->suspended = 0; + SIMIX_process_suspend(self,self); + } + if (self->doexception) { XBT_DEBUG("Wait, maestro left me an exception"); self->doexception = 0;