1 /* Copyright (c) 2013-2014. 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 /******************** Non-deterministic message ordering *********************/
8 /* This example implements one process which receives messages from two other */
9 /* processes. There is no bug on it, it is just provided to test the soundness*/
10 /* of the state space reduction with DPOR, if the maximum depth (defined with */
11 /* --cfg=model-check/max_depth:) is reached. */
12 /******************************************************************************/
15 #include <simgrid/modelchecker.h>
19 XBT_LOG_NEW_DEFAULT_CATEGORY(electric_fence, "Example to check the soundness of DPOR");
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 = NULL, task2 = NULL;
27 msg_comm_t comm_received1 = NULL, comm_received2 = NULL;
29 comm_received1 = MSG_task_irecv(&task1, "mymailbox");
30 comm_received2 = MSG_task_irecv(&task2, "mymailbox");
32 MSG_comm_wait(comm_received1, -1);
33 MSG_comm_wait(comm_received2, -1);
39 int client(int argc, char *argv[])
42 msg_task_t task = MSG_task_create(argv[1], 0, 10000, NULL);
44 MSG_task_send(task, "mymailbox");
50 int main(int argc, char *argv[])
53 MSG_init(&argc, argv);
55 MSG_create_environment("platform.xml");
57 MSG_function_register("server", server);
59 MSG_function_register("client", client);
61 MSG_launch_application("deploy_electric_fence.xml");