Go to the documentation of this file.
38 #ifndef __MEM_PHYSICAL_HH__
39 #define __MEM_PHYSICAL_HH__
73 bool conf_table_reported,
bool in_addr_map,
bool kvm_map)
165 bool conf_table_reported,
166 bool in_addr_map,
bool kvm_map);
175 bool mmap_using_noreserve,
176 const std::string& shared_backstore);
286 #endif //__MEM_PHYSICAL_HH__
std::vector< BackingStoreEntry > getBackingStore() const
Get the pointers to the backing store for external host access.
void serialize(CheckpointOut &cp) const override
Serialize all the memories in the system.
bool confTableReported
Whether this memory should be reported to the configuration table.
The AddrRangeMap uses an STL map to implement an interval tree for address decoding.
The physical memory encapsulates all memories in the system and provides basic functionality for acce...
bool inAddrMap
Whether this memory should appear in the global address map.
void access(PacketPtr pkt)
Perform an untimed memory access and update all the state (e.g.
void unserialize(CheckpointIn &cp) override
Unserialize the memories in the system.
std::vector< BackingStoreEntry > backingStore
void unserializeStore(CheckpointIn &cp)
Unserialize a specific backing store, identified by a section.
AddrRange range
The address range covered in the guest.
void serializeStore(CheckpointOut &cp, unsigned int store_id, AddrRange range, uint8_t *pmem) const
Serialize a specific store.
bool kvmMap
Whether KVM should map this memory into the guest address space during acceleration.
PhysicalMemory(const PhysicalMemory &)
AddrRangeMap< AbstractMemory *, 1 > addrMap
Basic support for object serialization.
BackingStoreEntry(AddrRange range, uint8_t *pmem, bool conf_table_reported, bool in_addr_map, bool kvm_map)
Create a backing store entry.
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
A single entry for the backing store.
~PhysicalMemory()
Unmap all the backing store we have used.
const bool mmapUsingNoReserve
const std::string sharedBackstore
std::vector< AbstractMemory * > memories
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
void functionalAccess(PacketPtr pkt)
Perform an untimed memory read or write without changing anything but the memory itself.
const std::string name() const
Return the name for debugging and for creation of sections for checkpointing.
PhysicalMemory & operator=(const PhysicalMemory &)
bool isMemAddr(Addr addr) const
Check if a physical address is within a range of a memory that is part of the global address map.
std::ostream CheckpointOut
uint64_t totalSize() const
Get the total physical memory size.
The AddrRange class encapsulates an address range, and supports a number of tests to check if two ran...
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
AddrRangeList getConfAddrRanges() const
Get the memory ranges for all memories that are to be reported to the configuration table.
uint8_t * pmem
Pointer to the host memory this range maps to.
void createBackingStore(AddrRange range, const std::vector< AbstractMemory * > &_memories, bool conf_table_reported, bool in_addr_map, bool kvm_map)
Create the memory region providing the backing store for a given address range that corresponds to a ...
Generated on Tue Dec 21 2021 11:34:32 for gem5 by doxygen 1.8.17