1 /* Copyright (c) 2014-2018. The SimGrid Team. All rights reserved. */
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. */
6 #ifndef SIMGRID_MC_MMU_HPP
7 #define SIMGRID_MC_MMU_HPP
12 #ifndef XBT_ALWAYS_INLINE
13 #define XBT_ALWAYS_INLINE inline __attribute__((always_inline))
16 /** Cache the size of a memory page for the current system. */
17 extern "C" int xbt_pagesize;
18 /** Cache the number of bits of addresses inside a given page, log2(xbt_pagesize). */
19 extern "C" int xbt_pagebits;
23 // TODO, do not depend on xbt_pagesize/xbt_pagebits but our own chunk size
26 static int chunkSize()
31 /** @brief How many memory pages are necessary to store size bytes?
33 * @param size Byte size
34 * @return Number of memory pages
36 static XBT_ALWAYS_INLINE std::size_t chunkCount(std::size_t size)
38 size_t page_count = size >> xbt_pagebits;
39 if (size & (xbt_pagesize - 1))
44 /** @brief Split into chunk number and remaining offset */
45 static XBT_ALWAYS_INLINE std::pair<std::size_t, std::uintptr_t> split(std::uintptr_t offset)
47 return {offset >> xbt_pagebits, offset & (xbt_pagesize - 1)};
50 /** Merge chunk number and remaining offset info a global offset */
51 static XBT_ALWAYS_INLINE std::uintptr_t join(std::size_t page, std::uintptr_t offset)
53 return ((std::uintptr_t)page << xbt_pagebits) + offset;
56 static XBT_ALWAYS_INLINE std::uintptr_t join(std::pair<std::size_t, std::uintptr_t> value)
58 return join(value.first, value.second);
61 static XBT_ALWAYS_INLINE bool sameChunk(std::uintptr_t a, std::uintptr_t b)
63 return (a >> xbt_pagebits) == (b >> xbt_pagebits);