+int communicator::receiver_wrapper(int, char* [])
+{
+ communicator* comm;
+ comm = static_cast<communicator*>(MSG_process_get_data(MSG_process_self()));
+ int result = comm->receiver();
+
+ XBT_DEBUG("terminate");
+ xbt_mutex_acquire(comm->mutex);
+ comm->receiver_process = NULL;
+ xbt_cond_signal(comm->cond);
+ xbt_mutex_release(comm->mutex);
+
+ return result;
+}
+
+void communicator::receiver1(msg_comm_t& comm, m_task_t& task, const char* mbox)
+{
+ MSG_comm_destroy(comm);
+ if (strcmp(MSG_task_get_name(task), "finalize")) {
+ XBT_DEBUG("received message on %s", mbox);
+ xbt_mutex_acquire(mutex);
+ received.push(task);
+ xbt_cond_signal(cond);
+ xbt_mutex_release(mutex);
+ task = NULL;
+ comm = MSG_task_irecv(&task, mbox);
+ } else {
+ XBT_DEBUG("received finalize on %s", mbox);
+ MSG_task_destroy(task);
+ task = NULL;
+ comm = NULL;
+ }
+}
+
+int communicator::receiver()
+{
+ 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(mutex);
+ xbt_cond_signal(cond); // signal master that we are ready
+ xbt_mutex_release(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 recvd = MSG_comm_waitany(comms);
+ msg_comm_t comm = xbt_dynar_get_as(comms, recvd, msg_comm_t);
+ xbt_dynar_reset(comms);
+
+ 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);
+ }
+ }
+ xbt_dynar_free(&comms);
+ return 0;
+}
+