52 PortProxy::PortProxy(
const RequestPort &port, 
unsigned int cache_line_size) :
 
   59                         void *
p, 
int size)
 const 
   64         auto req = std::make_shared<Request>(
 
   65             gen.addr(), gen.size(), 
flags, Request::funcRequestorId);
 
   67         Packet pkt(req, MemCmd::ReadReq);
 
   70         p = 
static_cast<uint8_t *
>(
p) + gen.size();
 
   76                          const void *
p, 
int size)
 const 
   81         auto req = std::make_shared<Request>(
 
   82             gen.addr(), gen.size(), 
flags, Request::funcRequestorId);
 
   84         Packet pkt(req, MemCmd::WriteReq);
 
   87         p = 
static_cast<const uint8_t *
>(
p) + gen.size();
 
   93                           uint8_t 
v, 
int size)
 const 
   96     uint8_t *buf = 
new uint8_t[size];
 
   98     std::memset(buf, 
v, size);
 
   99     PortProxy::writeBlobPhys(
addr, 
flags, buf, size);
 
  105 PortProxy::tryWriteString(
Addr addr, 
const char *str)
 const 
  108         if (!tryWriteBlob(
addr++, str, 1))
 
  115 PortProxy::tryReadString(std::string &str, 
Addr addr)
 const 
  119         if (!tryReadBlob(
addr++, &
c, 1))
 
  128 PortProxy::tryReadString(
char *str, 
Addr addr, 
size_t maxlen)
 const 
  132         if (!tryReadBlob(
addr++, str, 1))
 
Declaration and inline definition of ChunkGenerator object.
This class takes an arbitrary memory region (address/length pair) and generates a series of appropria...
A Packet is used to encapsulate a transfer between two objects in the memory system (e....
void dataStatic(T *p)
Set the data pointer to the following value that should not be freed.
void dataStaticConst(const T *p)
Set the data pointer to the following value that should not be freed.
This object is a proxy for a port or other object which implements the functional response protocol,...
PortProxy(SendFunctionalFunc func, unsigned int cache_line_size)
A RequestPort is a specialisation of a Port, which implements the default protocol for the three diff...
ThreadContext is the external interface to all thread state for anything outside of the CPU.
bool done() const
Are we done? That is, did the last call to next() advance past the end of the region?
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
PortProxy Object Declaration.