- if (ctrl_comm && comm_test_n_destroy(ctrl_comm)) {
- if (strcmp(MSG_task_get_name(ctrl_task), "finalize")) {
- DEBUG0("received message from ctrl");
- xbt_mutex_acquire(mutex);
- received.push(ctrl_task);
- xbt_mutex_release(mutex);
- ctrl_task = NULL;
- ctrl_comm = MSG_task_irecv(&ctrl_task, get_ctrl_mbox());
- } else {
- DEBUG0("received finalize from ctrl");
- MSG_task_destroy(ctrl_task);
- ctrl_task = NULL;
- ctrl_comm = NULL;
- }
- }
-
- if (data_comm && comm_test_n_destroy(data_comm)) {
- if (strcmp(MSG_task_get_name(data_task), "finalize")) {
- DEBUG0("received message from data");
- xbt_mutex_acquire(mutex);
- received.push(data_task);
- xbt_mutex_release(mutex);
- data_task = NULL;
- data_comm = MSG_task_irecv(&data_task, get_data_mbox());
- } else {
- DEBUG0("received finalize from data");
- MSG_task_destroy(data_task);
- data_task = NULL;
- data_comm = NULL;
- }
+ if (comm == ctrl_comm)
+ receiver1(ctrl_comm, ctrl_task, get_ctrl_mbox());
+ else if (comm == data_comm)
+ receiver1(data_comm, data_task, get_data_mbox());
+ else {
+ XBT_ERROR("Handling unknown comm -- %p", comm);
+ MSG_comm_destroy(comm);