/* alloc structures */
act = xbt_new0(s_smx_action_t, 1);
act->cond_list = xbt_fifo_new();
+ act->sem_list = xbt_fifo_new();
/* initialize them */
act->name = xbt_strdup(name);
/* alloc structures */
act = xbt_new0(s_smx_action_t, 1);
act->cond_list = xbt_fifo_new();
+ act->sem_list = xbt_fifo_new();
/* initialize them */
act->source = host;
/* alloc structures */
act = xbt_new0(s_smx_action_t, 1);
act->cond_list = xbt_fifo_new();
+ act->sem_list = xbt_fifo_new();
/* initialize them */
act->source = host;
"Conditional list not empty %d. There is a problem. Cannot destroy it now!",
xbt_fifo_size(action->cond_list));
+ xbt_assert1((xbt_fifo_size(action->sem_list) == 0),
+ "Semaphore list not empty %d. There is a problem. Cannot destroy it now!",
+ xbt_fifo_size(action->sem_list));
+
DEBUG1("Destroy action %p", action);
if (action->name)
xbt_free(action->name);
xbt_fifo_free(action->cond_list);
+ xbt_fifo_free(action->sem_list);
if (action->surf_action)
action->surf_action->model_type->action_unref(action->surf_action);
}
/**
- * \brief Set an action to a condition
+ * \brief Set an action to a condition
*
- * Creates the "link" between an action and a condition. You have to call this function when you create an action and want to wait its ending.
- * \param action SIMIX action
- * \param cond SIMIX cond
+ * Creates the "link" between an action and a condition. You have to call this function when you create an action and want to wait its ending.
+ * \param action SIMIX action
+ * \param cond SIMIX cond
*/
void SIMIX_register_action_to_condition(smx_action_t action, smx_cond_t cond)
{
}
/**
- * \brief Unset an action to a condition.
+ * \brief Unset an action to a condition.
*
- * Destroys the "links" from the condition to this action.
- * \param action SIMIX action
- * \param cond SIMIX cond
+ * Destroys the "links" from the condition to this action.
+ * \param action SIMIX action
+ * \param cond SIMIX cond
*/
void SIMIX_unregister_action_to_condition(smx_action_t action,
smx_cond_t cond)
if(XBT_LOG_ISENABLED(simix_action, xbt_log_priority_debug))
__SIMIX_action_display_conditions(action);
-
+
xbt_fifo_remove_all(action->cond_list, cond);
if(XBT_LOG_ISENABLED(simix_action, xbt_log_priority_debug))
__SIMIX_action_display_conditions(action);
}
+/**
+ * \brief Link an action to a semaphore
+ *
+ * When the action terminates, the semaphore gets signaled automatically.
+ */
+void SIMIX_register_action_to_semaphore(smx_action_t action, smx_sem_t sem) {
+
+ DEBUG2("Register action %p to semaphore %p (and otherwise)", action, sem);
+ xbt_fifo_push(sem->actions, action);
+ xbt_fifo_push(action->sem_list, sem);
+}
+/**
+ * \brief Unset an action to a semaphore.
+ *
+ * Destroys the "links" from the semaphore to this action.
+ */
+void SIMIX_unregister_action_to_semaphore(smx_action_t action,
+ smx_sem_t sem)
+{
+ xbt_fifo_remove_all(sem->actions, action);
+ xbt_fifo_remove_all(action->sem_list, sem);
+}
/**
* \brief Return how much remais to be done in the action.
/* alloc structures */
act = xbt_new0(s_smx_action_t, 1);
act->cond_list = xbt_fifo_new();
+ act->sem_list = xbt_fifo_new();
/* initialize them */
act->name = xbt_strdup(name);
action->name = name;
}
-void SIMIX_action_signal_all(smx_action_t action)
-{
+/** @brief broadcast any condition and release any semaphore including this action */
+void SIMIX_action_signal_all(smx_action_t action){
smx_cond_t cond;
+ smx_sem_t sem;
while ((cond = xbt_fifo_pop(action->cond_list)))
SIMIX_cond_broadcast(cond);
- return;
+ while ((sem = xbt_fifo_pop(action->sem_list)))
+ SIMIX_sem_release(sem);
}