+ ctrl_comm = MSG_task_irecv(&ctrl_task, get_ctrl_mbox());
+ data_comm = MSG_task_irecv(&data_task, get_data_mbox());
+ XBT_DEBUG("receiver ready");
+ xbt_mutex_acquire(receiver_mutex);
+ xbt_cond_signal(receiver_cond); // signal master that we are ready
+ xbt_mutex_release(receiver_mutex);
+
+ xbt_dynar_t comms = xbt_dynar_new(sizeof(msg_comm_t), NULL);
+ while (ctrl_comm || data_comm) {
+
+ if (ctrl_comm)
+ xbt_dynar_push(comms, &ctrl_comm);
+ if (data_comm)
+ xbt_dynar_push(comms, &data_comm);
+ int index = MSG_comm_waitany(comms);
+ msg_comm_t finished_comm = xbt_dynar_get_as(comms, index, msg_comm_t);
+ xbt_dynar_reset(comms);
+
+ if (finished_comm == ctrl_comm)
+ receiver1(ctrl_comm, ctrl_task, get_ctrl_mbox());
+ else if (finished_comm == data_comm)
+ receiver1(data_comm, data_task, get_data_mbox());
+ else
+ THROW1(0, 0, "Cannot handle unknown comm -- %p", finished_comm);
+ }
+ xbt_dynar_free(&comms);
+ return 0;