Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
[mc] Use std::equal_range in get_search_range()
[simgrid.git] / src / mc / mc_smx.h
1 /* Copyright (c) 2015. 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 #ifndef SIMGRID_MC_SMX_H
8 #define SIMGRID_MC_SMX_H
9
10 #include <stddef.h>
11
12 #include <xbt/base.h>
13 #include <xbt/log.h>
14
15 #include <simgrid/simix.h>
16
17 #include "src/smpi/private.h"
18
19 #include "src/mc/Process.hpp"
20 #include "src/mc/mc_protocol.h"
21
22 /** @file
23  *  @brief (Cross-process, MCer/MCed) Access to SMX structures
24  *
25  *  We copy some C data structure from the MCed process in the MCer process.
26  *  This is implemented by:
27  *
28  *   - `model_checker->process.smx_process_infos`
29  *      (copy of `simix_global->process_list`);
30  *
31  *   - `model_checker->process.smx_old_process_infos`
32  *      (copy of `simix_global->process_to_destroy`);
33  *
34  *   - `model_checker->hostnames`.
35  *
36  * The process lists are currently refreshed each time MCed code is executed.
37  * We don't try to give a persistent MCer address for a given MCed process.
38  * For this reason, a MCer simgrid::mc::Process* is currently not reusable after
39  * MCed code.
40  */
41
42 SG_BEGIN_DECL()
43
44 XBT_PRIVATE void MC_process_smx_refresh(simgrid::mc::Process* process);
45
46 /** Get the issuer of  a simcall (`req->issuer`)
47  *
48  *  In split-process mode, it does the black magic necessary to get an address
49  *  of a (shallow) copy of the data structure the issuer SIMIX process in the local
50  *  address space.
51  *
52  *  @param process the MCed process
53  *  @param req     the simcall (copied in the local process)
54  */
55 XBT_PRIVATE smx_process_t MC_smx_simcall_get_issuer(smx_simcall_t req);
56
57 XBT_PRIVATE const char* MC_smx_process_get_name(smx_process_t p);
58 XBT_PRIVATE const char* MC_smx_process_get_host_name(smx_process_t p);
59
60 XBT_PRIVATE int MC_smpi_process_count(void);
61
62
63 /* ***** Resolve (local/MCer structure from remote/MCed addresses) ***** */
64
65 /** Get a local copy of the process from the process remote address */
66 XBT_PRIVATE smx_process_t MC_smx_resolve_process(smx_process_t process_remote_address);
67
68 /** Get the process info structure from the process remote address */
69 XBT_PRIVATE simgrid::mc::SimixProcessInformation* MC_smx_resolve_process_info(smx_process_t process_remote_address);
70
71 XBT_PRIVATE unsigned long MC_smx_get_maxpid(void);
72
73 SG_END_DECL()
74
75 #endif