1 /* Copyright (c) 2010-2015. The SimGrid Team.
2 * All rights reserved. */
4 /* This program is free software; you can redistribute it and/or modify it
5 * under the terms of the license (GNU LGPL) which comes with this package. */
7 /**************** Shared buffer between asynchronous receives *****************/
8 /* Server process assumes that the data from the second communication comm2 */
9 /* will overwrite the one from the first communication, because of the order */
10 /* of the wait calls. This is not true because data copy can be triggered by */
11 /* a call to wait on the other end of the communication (client). */
12 /* NOTE that the communications use different mailboxes, but they share the */
13 /* same buffer for reception (task1). */
14 /******************************************************************************/
16 #include <simgrid/msg.h>
17 #include <simgrid/modelchecker.h>
19 XBT_LOG_NEW_DEFAULT_CATEGORY(bugged3, "this example");
21 int server(int argc, char *argv[]);
22 int client(int argc, char *argv[]);
24 int server(int argc, char *argv[])
26 msg_task_t task1,task2;
28 msg_comm_t comm1 = MSG_task_irecv(&task1, "mymailbox1");
29 msg_comm_t comm2 = MSG_task_irecv(&task2, "mymailbox2");
30 MSG_comm_wait(comm1, -1);
31 MSG_comm_wait(comm2, -1);
33 long val1 = xbt_str_parse_int(MSG_task_get_name(task1), "Task name is not a numerical ID: %s");
34 XBT_INFO("Received %lu", val1);
42 int client(int argc, char *argv[])
44 msg_task_t task1 = MSG_task_create(argv[1], 0, 10000, NULL);
46 char *mbox = bprintf("mymailbox%s", argv[1]);
48 XBT_INFO("Send %s!", argv[1]);
49 msg_comm_t comm = MSG_task_isend(task1, mbox);
50 MSG_comm_wait(comm, -1);
57 int main(int argc, char *argv[])
59 MSG_init(&argc, argv);
61 MSG_create_environment("platform.xml");
63 MSG_function_register("server", server);
64 MSG_function_register("client", client);
65 MSG_launch_application("deploy_bugged3.xml");