receiver->simdata->host, size, rate);
surf_workstation_resource->common_public->action_set_data(simdata->surf_action,act);
+ DEBUG1("Create communicate action %p",act);
return act;
}
surf_workstation_resource->common_public->action_set_data(simdata->surf_action,act);
+ DEBUG1("Create execute action %p",act);
return act;
}
surf_workstation_resource->common_public->action_set_data(simdata->surf_action,act);
+ DEBUG1("Create sleep action %p",act);
return act;
}
{
xbt_assert0((action != NULL), "Invalid parameter");
+ DEBUG1("Cancel action %p",action);
if(action->simdata->surf_action) {
surf_workstation_resource->common_public->action_cancel(action->simdata->surf_action);
}
xbt_assert1((xbt_fifo_size(action->cond_list)==0),
"Conditional list not empty %d. There is a problem. Cannot destroy it now!", xbt_fifo_size(action->cond_list));
+ DEBUG1("Destroy action %p",action);
if(action->name) xbt_free(action->name);
xbt_fifo_free(action->cond_list);
{
xbt_assert0( (action != NULL) && (cond != NULL), "Invalid parameters");
+ DEBUG2("Register action %p to condtion %p",action,cond);
xbt_fifo_push(cond->actions,action);
}
*/
void SIMIX_cond_signal(smx_cond_t cond)
{
+ DEBUG1("Signal condition %p",cond);
xbt_assert0((cond != NULL), "Invalid parameters");
smx_process_t proc = NULL;
smx_action_t act_sleep;
xbt_assert0((mutex != NULL), "Invalid parameters");
+ DEBUG1("Wait condition %p",cond);
cond->mutex = mutex;
SIMIX_mutex_unlock(mutex);
xbt_assert0((mutex != NULL), "Invalid parameters");
smx_action_t act_sleep;
+ DEBUG1("Timed wait condition %p",cond);
cond->mutex = mutex;
SIMIX_mutex_unlock(mutex);
smx_process_t proc = NULL;
smx_process_t proc_next = NULL;
+ DEBUG1("Broadcast condition %p",cond);
xbt_swag_foreach_safe(proc,proc_next,cond->sleeping) {
xbt_swag_remove(proc,cond->sleeping);
xbt_swag_insert(proc, simix_global->process_to_run);
*/
void SIMIX_cond_destroy(smx_cond_t cond)
{
+ DEBUG1("Destroy condition %p",cond);
+ xbt_backtrace_display_current();
if ( cond == NULL )
return ;
else {
- xbt_assert0( xbt_swag_size(cond->sleeping) == 0 , "Cannot destroy conditional");
+ xbt_assert0( xbt_swag_size(cond->sleeping) == 0 , "Cannot destroy conditional since someone is still using it");
xbt_swag_free(cond->sleeping);
xbt_fifo_free(cond->actions);
xbt_free(cond);
{
xbt_assert0( (action != NULL) && (cond != NULL), "Invalid parameters");
+ DEBUG2("Register condition %p to action %p",cond,action);
xbt_fifo_push(action->cond_list,cond);
}