XBT_LOG_NEW_DEFAULT_CATEGORY(random_bug, "For this example");
-enum class Behavior { ABORT, ASSERT, PRINTF };
+enum class Behavior { ABORT, ASSERT, PRINTF, SEGV };
Behavior behavior;
} else if (behavior == Behavior::PRINTF) {
if (x == 3 && y == 4)
XBT_ERROR("Error reached");
- } else { // behavior == Behavior::ABORT
- abort();
+ } else if (behavior == Behavior::ABORT) {
+ if (x == 3 && y == 4)
+ abort();
+ } else if (behavior == Behavior::SEGV) {
+ int* A = 0;
+ if (x == 3 && y == 4)
+ *A = 1;
+ } else {
+ DIE_IMPOSSIBLE;
}
}
int main(int argc, char* argv[])
{
simgrid::s4u::Engine e(&argc, argv);
- xbt_assert(argc == 3, "Usage: random-bug abort|assert|printf <platformfile>");
+ xbt_assert(argc == 3, "Usage: random-bug abort|assert|printf|segv <platformfile>");
if (strcmp(argv[1], "abort") == 0) {
XBT_INFO("Behavior: abort");
behavior = Behavior::ABORT;
} else if (strcmp(argv[1], "printf") == 0) {
XBT_INFO("Behavior: printf");
behavior = Behavior::PRINTF;
+ } else if (strcmp(argv[1], "segv") == 0) {
+ XBT_INFO("Behavior: segv");
+ behavior = Behavior::SEGV;
} else {
- xbt_die("Please use either 'abort', 'assert' or 'printf' as first parameter, to specify what to do when the error "
+ xbt_die("Please use either 'abort', 'assert', 'printf', or 'segv' as first parameter, to specify what to do when "
+ "the error "
"is found.");
}
> [ 0.000000] (0:maestro@) **************************
> [ 0.000000] (0:maestro@) From signal: Aborted
> [ 0.000000] (0:maestro@) Counter-example execution trace:
-> [ 0.000000] (0:maestro@) [(1)Fafard (app)] MC_RANDOM(0)
-> [ 0.000000] (0:maestro@) [(1)Fafard (app)] MC_RANDOM(0)
-> [ 0.000000] (0:maestro@) Path = 1;1
-> [ 0.000000] (0:maestro@) Expanded states = 2
-> [ 0.000000] (0:maestro@) Visited states = 2
-> [ 0.000000] (0:maestro@) Executed transitions = 2
+> [ 0.000000] (0:maestro@) [(1)Fafard (app)] MC_RANDOM(3)
+> [ 0.000000] (0:maestro@) [(1)Fafard (app)] MC_RANDOM(4)
+> [ 0.000000] (0:maestro@) Path = 1/3;1/4
+> [ 0.000000] (0:maestro@) Expanded states = 27
+> [ 0.000000] (0:maestro@) Visited states = 68
+> [ 0.000000] (0:maestro@) Executed transitions = 46
> [ 0.000000] (0:maestro@) Stack trace not displayed because you passed --log=no_loc
$ ${bindir:=.}/../../../bin/simgrid-mc ${bindir:=.}/random-bug printf ${platfdir}/small_platform.xml "--log=root.fmt:[%10.6r]%e(%i:%a@%h)%e%m%n" --log=xbt_cfg.thresh:warning
> [ 0.000000] (0:maestro@) Expanded states = 43
> [ 0.000000] (0:maestro@) Visited states = 108
> [ 0.000000] (0:maestro@) Executed transitions = 72
+
+! expect return 6
+# because SIMGRID_MC_EXIT_PROGRAM_CRASH = 6
+$ ${bindir:=.}/../../../bin/simgrid-mc ${bindir:=.}/random-bug segv ${platfdir}/small_platform.xml "--log=root.fmt:[%10.6r]%e(%i:%a@%h)%e%m%n" --log=xbt_cfg.thresh:warning --log=no_loc
+> [ 0.000000] (0:maestro@) Check a safety property. Reduction is: dpor.
+> [ 0.000000] (0:maestro@) Behavior: segv
+> Segmentation fault.
+> [ 0.000000] (0:maestro@) **************************
+> [ 0.000000] (0:maestro@) ** CRASH IN THE PROGRAM **
+> [ 0.000000] (0:maestro@) **************************
+> [ 0.000000] (0:maestro@) From signal: Segmentation fault
+> [ 0.000000] (0:maestro@) Counter-example execution trace:
+> [ 0.000000] (0:maestro@) [(1)Fafard (app)] MC_RANDOM(3)
+> [ 0.000000] (0:maestro@) [(1)Fafard (app)] MC_RANDOM(4)
+> [ 0.000000] (0:maestro@) Path = 1/3;1/4
+> [ 0.000000] (0:maestro@) Expanded states = 27
+> [ 0.000000] (0:maestro@) Visited states = 68
+> [ 0.000000] (0:maestro@) Executed transitions = 46
+> [ 0.000000] (0:maestro@) Stack trace not displayed because you passed --log=no_loc