X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/2211665cb451243f182fa49a18219331d9bf58d6..0049d1fcfdafba3893e26714d575755194949765:/src/mc/Process.hpp diff --git a/src/mc/Process.hpp b/src/mc/Process.hpp index 223711acc2..512f6f26af 100644 --- a/src/mc/Process.hpp +++ b/src/mc/Process.hpp @@ -28,13 +28,16 @@ #include "src/simix/popping_private.h" #include "src/simix/smx_private.h" +#include "../xbt/memory_map.hpp" + #include "mc_forward.hpp" #include "mc_base.h" #include "mc_mmalloc.h" // std_heap -#include "mc_memory_map.h" #include "AddressSpace.hpp" #include "mc_protocol.h" +#include "ObjectInformation.hpp" + // Those flags are used to track down which cached information // is still up to date and which information needs to be updated. typedef int mc_process_cache_flags_t; @@ -154,6 +157,16 @@ public: void reset_soft_dirty(); void read_pagemap(uint64_t* pagemap, size_t start_page, size_t page_count); + bool privatized(ObjectInformation const& info) const + { + return privatized_ && info.executable(); + } + bool privatized() const + { + return privatized_; + } + void privatized(bool privatized) { privatized_ = privatized; } + private: void init_memory_map_info(); void refresh_heap(); @@ -163,12 +176,13 @@ private: int socket_; int status_; bool running_; - std::vector memory_map_; + std::vector memory_map_; remote_ptr maestro_stack_start_, maestro_stack_end_; int memory_file; std::vector ignored_regions_; int clear_refs_fd_; int pagemap_fd_; + bool privatized_; public: // object info // TODO, make private (first, objectify simgrid::mc::ObjectInformation*) std::vector> object_infos;