Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Merge branch 'master' of https://framagit.org/simgrid/simgrid
[simgrid.git] / src / mc / remote / CheckerSide.hpp
1 /* Copyright (c) 2007-2023. The SimGrid Team. All rights reserved.          */
2
3 /* This program is free software; you can redistribute it and/or modify it
4  * under the terms of the license (GNU LGPL) which comes with this package. */
5
6 #ifndef SIMGRID_MC_REMOTE_EVENTLOOP_HPP
7 #define SIMGRID_MC_REMOTE_EVENTLOOP_HPP
8
9 #include "src/mc/mc_forward.hpp"
10 #include "src/mc/remote/Channel.hpp"
11
12 #include <event2/event.h>
13 #include <functional>
14 #include <memory>
15
16 namespace simgrid::mc {
17
18 /* CheckerSide: All what the checker needs to interact with a given application process */
19
20 class CheckerSide {
21   std::unique_ptr<event_base, decltype(&event_base_free)> base_{nullptr, &event_base_free};
22   std::unique_ptr<event, decltype(&event_free)> socket_event_{nullptr, &event_free};
23   std::unique_ptr<event, decltype(&event_free)> signal_event_{nullptr, &event_free};
24   std::unique_ptr<RemoteProcessMemory> remote_memory_;
25   Channel channel_;
26
27   bool running_ = false;
28   pid_t pid_;
29
30   void setup_events(); // Part of the initialization
31   void clear_memory_cache();
32   void handle_waitpid();
33
34 public:
35   explicit CheckerSide(const std::vector<char*>& args);
36
37   // No copy:
38   CheckerSide(CheckerSide const&) = delete;
39   CheckerSide& operator=(CheckerSide const&) = delete;
40   CheckerSide& operator=(CheckerSide&&) = delete;
41
42   /* Communicating with the application */
43   Channel const& get_channel() const { return channel_; }
44   Channel& get_channel() { return channel_; }
45
46   bool handle_message(const char* buffer, ssize_t size);
47   void dispatch_events() const;
48   void break_loop() const;
49   void wait_for_requests();
50
51   /* Interacting with the application process */
52   pid_t get_pid() const { return pid_; }
53   bool running() const { return running_; }
54   void terminate() { running_ = false; }
55   RemoteProcessMemory& get_remote_memory() { return *remote_memory_.get(); }
56 };
57
58 } // namespace simgrid::mc
59
60 #endif