-static int do_child(int socket, char** argv)
-{
- XBT_DEBUG("Inside the child process PID=%i", (int) getpid());
-
-#ifdef __linux__
- // Make sure we do not outlive our parent:
- if (prctl(PR_SET_PDEATHSIG, SIGHUP) != 0) {
- std::perror("simgrid-mc");
- return SIMGRID_ERROR;
- }
-#endif
-
- int res;
-
- // Remove CLOEXEC in order to pass the socket to the exec-ed program:
- int fdflags = fcntl(socket, F_GETFD, 0);
- if (fdflags == -1) {
- std::perror("simgrid-mc");
- return SIMGRID_ERROR;
- }
- if (fcntl(socket, F_SETFD, fdflags & ~FD_CLOEXEC) == -1) {
- std::perror("simgrid-mc");
- return SIMGRID_ERROR;
- }
-
- XBT_DEBUG("CLOEXEC removed on socket %i", socket);
-
- // Set environment:
- setenv(MC_ENV_VARIABLE, "1", 1);
-
- // Disable lazy relocation in the model-ched process.
- // We don't want the model-checked process to modify its .got.plt during
- // snapshot.
- setenv("LC_BIND_NOW", "1", 1);
-
- char buffer[64];
- res = std::snprintf(buffer, sizeof(buffer), "%i", socket);
- if ((size_t) res >= sizeof(buffer) || res == -1)
- return SIMGRID_ERROR;
- setenv(MC_ENV_SOCKET_FD, buffer, 1);
-
- execvp(argv[1], argv+1);
- XBT_ERROR("Could not execute the child process");
- return SIMGRID_ERROR;
-}
-
-static int do_parent(int socket, pid_t child)
-{
- XBT_DEBUG("Inside the parent process");
- if (simgrid::mc::server)
- xbt_die("MC server already present");
- try {
- mc_mode = MC_MODE_SERVER;
- simgrid::mc::server = new simgrid::mc::Server(child, socket);
- simgrid::mc::server->start();
- if (_sg_mc_comms_determinism || _sg_mc_send_determinism)
- MC_modelcheck_comm_determinism();
- else if (!_sg_mc_property_file || _sg_mc_property_file[0] == '\0')
- MC_modelcheck_safety();
- else
- MC_modelcheck_liveness();
- simgrid::mc::server->shutdown();
- simgrid::mc::server->exit();
- }
- catch(std::exception& e) {
- XBT_ERROR("Exception: %s", e.what());
- }
- exit(SIMGRID_ERROR);
-}
-
-static char** argvdup(int argc, char** argv)