Go to the documentation of this file.
29 #ifndef __SRC_MEM_VMA_HH__
30 #define __SRC_MEM_VMA_HH__
37 #include "debug/Vma.hh"
49 int fd=-1, off_t off=0)
52 DPRINTF(Vma,
"Creating vma start %#x len %llu end %#x\n",
53 r.start(),
r.size(),
r.end());
57 std::make_shared<MappedFileBuffer>(
fd,
r.size(), off);
203 #endif // __SRC_MEM_VMA_HH__
AddrRange _addrRange
Address range for this virtual memory area.
Addr start() const
Get the start address of the range.
bool hasHostBuf() const
Check if the virtual memory area has an equivalent buffer on the host machine.
MappedFileBuffer(int fd, size_t length, off_t offset)
MappedFileBuffer is a wrapper around a region of host memory backed by a file.
std::string _vmaName
Human-readable name associated with the virtual memory area.
bool contains(const Addr &a) const
bool contains(const Addr &a) const
Determine if the range contains an address.
void fillMemPages(Addr start, Addr size, PortProxy &port) const
Copy memory from a buffer which resides on the host machine into a section of memory on the target.
bool isSubset(const AddrRange &r) const
Addr _pageBytes
Number of bytes in an OS page.
bool intersects(const AddrRange &r) const
Determine if another range intersects this one, i.e.
bool isSubset(const AddrRange &r) const
Determine if this range is a subset of another range, i.e.
bool isStrictSuperset(const AddrRange &range) const
Returns true if desired range exists within this virtual memory area and does not include the start a...
const std::string & getName()
Addr size()
Defer AddrRange related calls to the AddrRange.
void remap(Addr new_start)
Remap the virtual memory area starting at new_start.
bool intersects(const AddrRange &r) const
This object is a proxy for a port or other object which implements the functional response protocol,...
bool mergesWith(const AddrRange &r) const
Addr size() const
Get the size of the address range.
Addr end() const
Get the end address of the range.
uint64_t _hostBufLen
Length of host buffer for this virtual memory area.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
void * _hostBuf
Host buffer ptr for this virtual memory area.
bool mergesWith(const AddrRange &r) const
Determine if another range merges with the current one, i.e.
VMA(AddrRange r, Addr page_bytes, const std::string &vma_name="anon", int fd=-1, off_t off=0)
void sliceRegionLeft(Addr slice_addr)
Remove the address range to the left of slice_addr.
std::shared_ptr< MappedFileBuffer > _origHostBuf
The host file backing will be chopped up and reassigned as pages are mapped, remapped,...
void sliceRegionRight(Addr slice_addr)
Remove the address range to the right of slice_addr.
The AddrRange class encapsulates an address range, and supports a number of tests to check if two ran...
uint64_t getLength() const
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Generated on Tue Dec 21 2021 11:34:35 for gem5 by doxygen 1.8.17