Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
27703a7a4cc591452e19287d4defc709b92012eb
[simgrid.git] / examples / msg / mc / test / snapshot_comparison_liveness3.c
1 /* Copyright (c) 2012. The SimGrid Team.
2  * All rights reserved.                                                     */
3
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. */
6
7 #include <msg/msg.h>
8 #include <simgrid/modelchecker.h>
9 #include "mc/mc.h"
10
11 XBT_LOG_NEW_DEFAULT_CATEGORY(snapshot_comparison_liveness3, "Debug information for snasphot comparison liveness1 test example");
12
13 int test(int argc, char **argv);
14
15 int test(int argc, char **argv){
16
17   MSG_process_sleep(1);
18
19   XBT_INFO("**** Start test ****");
20   XBT_INFO("Malloc and free after first snapshot");
21
22   char *toto = NULL;
23
24   void *snap1 = MC_snapshot();
25
26   MSG_process_sleep(1);
27
28   toto = xbt_malloc(5);
29   XBT_INFO("Toto allocated");
30   xbt_free(toto);
31   toto = NULL;
32   XBT_INFO("Toto free");
33
34   MSG_process_sleep(1);
35
36   void *snap2 = MC_snapshot();
37
38   MC_ignore_stack("snap2", "test");   
39   MC_ignore_stack("snap1", "test");
40
41   XBT_INFO("Test result : %d (0 = state equality, 1 = different states)", MC_compare_snapshots(snap1, snap2));
42   
43   XBT_INFO("**** End test ****");
44
45   return 0;
46 }
47
48 int main(int argc, char **argv){
49   MSG_init(&argc, argv);
50   
51   MSG_config("model-check/property","promela");
52
53   MSG_create_environment("snapshot_comparison_platform.xml");
54
55   MSG_function_register("test", test);
56
57   MSG_launch_application("deploy_snapshot_comparison.xml");
58
59   MSG_main();
60
61   return 0;
62 }