- 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 {
- XBT_ERROR("Handling unknown comm -- %p", finished_comm);
- MSG_comm_destroy(finished_comm);
- }
- }
- xbt_dynar_free(&comms);
- return 0;