Go to the documentation of this file.
41 : pageShift(page_shift), startPageNum(ptr >> page_shift),
42 freePageNum(ptr >> page_shift),
43 _totalPages((
limit - ptr) >> page_shift)
121 "Out of memory, please increase size of physical memory.");
147 for (
const auto &
mem : memories)
154 return pools[pool_id].allocate(npages);
160 return pools[pool_id].totalBytes();
166 return pools[pool_id].freeBytes();
173 int num_pools =
pools.size();
176 for (
int i = 0;
i < num_pools;
i++)
190 for (
int i = 0;
i < num_pools;
i++) {
193 pools.push_back(pool);
void unserialize(CheckpointIn &cp) override
Unserialize an object.
#define UNSERIALIZE_SCALAR(scalar)
Counter freePages() const
void serializeSection(CheckpointOut &cp, const char *name) const
Serialize an object into a new section.
std::string csprintf(const char *format, const Args &...args)
BitfieldType< SegDescriptorLimit > limit
Counter startPageNum
Start page of pool.
void serialize(CheckpointOut &cp) const override
Serialize an object.
Class for handling allocation of physical pages in SE mode.
void populate(const AddrRangeList &memories)
Counter totalPages() const
void setFreePage(Counter value)
void unserializeSection(CheckpointIn &cp, const char *name)
Unserialize an a child object.
Addr allocate(Addr npages)
Addr allocPhysPages(int npages, int pool_id=0)
Allocate npages contiguous unused physical pages.
Addr memSize(int pool_id=0) const
Amount of physical memory that exists in a pool.
Counter allocatedPages() const
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Addr allocatedBytes() const
#define SERIALIZE_SCALAR(scalar)
void serialize(CheckpointOut &cp) const override
Serialize an object.
Addr freePageAddr() const
void paramOut(CheckpointOut &cp, const std::string &name, ExtMachInst const &machInst)
void unserialize(CheckpointIn &cp) override
Unserialize an object.
void paramIn(CheckpointIn &cp, const std::string &name, ExtMachInst &machInst)
double Counter
All counters are of 64-bit values.
Counter startPage() const
Addr freeMemSize(int pool_id=0) const
Amount of physical memory that is still free in a pool.
std::ostream CheckpointOut
Counter freePageNum
Page number of free memory.
#define gem5_assert(cond,...)
The assert macro will function like a normal assert, but will use panic instead of straight abort().
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Counter _totalPages
The size of the pool, in number of pages.
std::vector< MemPool > pools
Generated on Wed Jul 13 2022 10:39:27 for gem5 by doxygen 1.8.17