X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/84183e4f4aa50f6220315835894bc0677c0ea64c..5838ca84fc5da29f60e79a41454680735eece98f:/src/mc/mc_page_store.h diff --git a/src/mc/mc_page_store.h b/src/mc/mc_page_store.h index 3caa88519e..de67f55da2 100644 --- a/src/mc/mc_page_store.h +++ b/src/mc/mc_page_store.h @@ -6,11 +6,13 @@ #include +#ifdef __cplusplus #include #include #include #include +#endif #include @@ -20,6 +22,10 @@ #ifndef MC_PAGE_SNAPSHOT_H #define MC_PAGE_SNAPSHOT_H +struct s_mc_pages_store; + +#ifdef __cplusplus + /** @brief Storage for snapshot memory pages * * The first (lower) layer of the per-page snapshot mechanism is a page @@ -79,7 +85,10 @@ private: // Types typedef boost::unordered_map pages_map_type; private: // Fields: - /** First page */ + /** First page + * + * mc_page_store_get_page expects that this is the first field. + * */ void* memory_; /** Number of available pages in virtual memory */ size_t capacity_; @@ -186,3 +195,14 @@ size_t s_mc_pages_store::capacity() { #endif +/** + */ +static inline __attribute__((always_inline)) +const void* mc_page_store_get_page(mc_pages_store_t page_store, size_t pageno) +{ + // This is page_store->memory_: + void* memory = *(void**)page_store; + return mc_page_from_number(memory, pageno); +} + +#endif