diff options
author | Andreas Hansson <andreas.hansson@arm.com> | 2015-01-22 05:00:53 -0500 |
---|---|---|
committer | Andreas Hansson <andreas.hansson@arm.com> | 2015-01-22 05:00:53 -0500 |
commit | f49830ce0ba79c54c65c9c4b25bc3c6184aaf2a9 (patch) | |
tree | 00b2f9f0131ef65a411c9fd81339caecfc946b47 /src/mem | |
parent | be3a952394e1f337d1c372448ee099203336181a (diff) | |
download | gem5-f49830ce0ba79c54c65c9c4b25bc3c6184aaf2a9.tar.xz |
mem: Clean up Request initialisation
This patch tidies up how we create and set the fields of a Request. In
essence it tries to use the constructor where possible (as opposed to
setPhys and setVirt), thus avoiding spreading the information across a
number of locations. In fact, setPhys is made private as part of this
patch, and a number of places where we callede setVirt instead uses
the appropriate constructor.
Diffstat (limited to 'src/mem')
-rw-r--r-- | src/mem/port_proxy.cc | 8 | ||||
-rw-r--r-- | src/mem/request.hh | 82 | ||||
-rw-r--r-- | src/mem/ruby/system/CacheRecorder.cc | 8 |
3 files changed, 46 insertions, 52 deletions
diff --git a/src/mem/port_proxy.cc b/src/mem/port_proxy.cc index cce8f6ff4..f0158ec2d 100644 --- a/src/mem/port_proxy.cc +++ b/src/mem/port_proxy.cc @@ -43,11 +43,9 @@ void PortProxy::readBlob(Addr addr, uint8_t *p, int size) const { - Request req; - for (ChunkGenerator gen(addr, size, _cacheLineSize); !gen.done(); gen.next()) { - req.setPhys(gen.addr(), gen.size(), 0, Request::funcMasterId); + Request req(gen.addr(), gen.size(), 0, Request::funcMasterId); Packet pkt(&req, MemCmd::ReadReq); pkt.dataStatic(p); _port.sendFunctional(&pkt); @@ -58,11 +56,9 @@ PortProxy::readBlob(Addr addr, uint8_t *p, int size) const void PortProxy::writeBlob(Addr addr, const uint8_t *p, int size) const { - Request req; - for (ChunkGenerator gen(addr, size, _cacheLineSize); !gen.done(); gen.next()) { - req.setPhys(gen.addr(), gen.size(), 0, Request::funcMasterId); + Request req(gen.addr(), gen.size(), 0, Request::funcMasterId); Packet pkt(&req, MemCmd::WriteReq); pkt.dataStaticConst(p); _port.sendFunctional(&pkt); diff --git a/src/mem/request.hh b/src/mem/request.hh index 15798ecc0..e844a6edb 100644 --- a/src/mem/request.hh +++ b/src/mem/request.hh @@ -198,6 +198,28 @@ class Request VALID_CONTEXT_ID | VALID_THREAD_ID; private: + + /** + * Set up a physical (e.g. device) request in a previously + * allocated Request object. + */ + void + setPhys(Addr paddr, unsigned size, Flags flags, MasterID mid, Tick time) + { + assert(size >= 0); + _paddr = paddr; + _size = size; + _time = time; + _masterId = mid; + _flags.clear(~STICKY_FLAGS); + _flags.set(flags); + privateFlags.clear(~STICKY_PRIVATE_FLAGS); + privateFlags.set(VALID_PADDR|VALID_SIZE); + depth = 0; + accessDelta = 0; + //translateDelta = 0; + } + /** * The physical address of the request. Valid only if validPaddr * is set. @@ -209,7 +231,7 @@ class Request * paddr is written via setVirt() or setPhys(), so it is always * valid as long as one of the address fields is valid. */ - int _size; + unsigned _size; /** The requestor ID which is unique in the system for all ports * that are capable of issuing a transaction @@ -254,9 +276,11 @@ class Request Addr _pc; public: - /** Minimal constructor. No fields are initialized. - * (Note that _flags and privateFlags are cleared by Flags - * default constructor.) + + /** + * Minimal constructor. No fields are initialized. (Note that + * _flags and privateFlags are cleared by Flags default + * constructor.) */ Request() : _paddr(0), _size(0), _masterId(invldMasterId), _time(0), @@ -268,18 +292,18 @@ class Request /** * Constructor for physical (e.g. device) requests. Initializes * just physical address, size, flags, and timestamp (to curTick()). - * These fields are adequate to perform a request. + * These fields are adequate to perform a request. */ - Request(Addr paddr, int size, Flags flags, MasterID mid) + Request(Addr paddr, unsigned size, Flags flags, MasterID mid) : _paddr(0), _size(0), _masterId(invldMasterId), _time(0), _taskId(ContextSwitchTaskId::Unknown), _asid(0), _vaddr(0), _extraData(0), _contextId(0), _threadId(0), _pc(0), translateDelta(0), accessDelta(0), depth(0) { - setPhys(paddr, size, flags, mid); + setPhys(paddr, size, flags, mid, curTick()); } - Request(Addr paddr, int size, Flags flags, MasterID mid, Tick time) + Request(Addr paddr, unsigned size, Flags flags, MasterID mid, Tick time) : _paddr(0), _size(0), _masterId(invldMasterId), _time(0), _taskId(ContextSwitchTaskId::Unknown), _asid(0), _vaddr(0), _extraData(0), _contextId(0), _threadId(0), _pc(0), @@ -288,7 +312,8 @@ class Request setPhys(paddr, size, flags, mid, time); } - Request(Addr paddr, int size, Flags flags, MasterID mid, Tick time, Addr pc) + Request(Addr paddr, unsigned size, Flags flags, MasterID mid, Tick time, + Addr pc) : _paddr(0), _size(0), _masterId(invldMasterId), _time(0), _taskId(ContextSwitchTaskId::Unknown), _asid(0), _vaddr(0), _extraData(0), _contextId(0), _threadId(0), _pc(0), @@ -299,7 +324,8 @@ class Request _pc = pc; } - Request(int asid, Addr vaddr, int size, Flags flags, MasterID mid, Addr pc, + Request(int asid, Addr vaddr, unsigned size, Flags flags, MasterID mid, + Addr pc, int cid, ThreadID tid) : _paddr(0), _size(0), _masterId(invldMasterId), _time(0), _taskId(ContextSwitchTaskId::Unknown), _asid(0), _vaddr(0), @@ -324,38 +350,12 @@ class Request } /** - * Set up a physical (e.g. device) request in a previously - * allocated Request object. - */ - void - setPhys(Addr paddr, int size, Flags flags, MasterID mid, Tick time) - { - assert(size >= 0); - _paddr = paddr; - _size = size; - _time = time; - _masterId = mid; - _flags.clear(~STICKY_FLAGS); - _flags.set(flags); - privateFlags.clear(~STICKY_PRIVATE_FLAGS); - privateFlags.set(VALID_PADDR|VALID_SIZE); - depth = 0; - accessDelta = 0; - //translateDelta = 0; - } - - void - setPhys(Addr paddr, int size, Flags flags, MasterID mid) - { - setPhys(paddr, size, flags, mid, curTick()); - } - - /** * Set up a virtual (e.g., CPU) request in a previously * allocated Request object. */ void - setVirt(int asid, Addr vaddr, int size, Flags flags, MasterID mid, Addr pc) + setVirt(int asid, Addr vaddr, unsigned size, Flags flags, MasterID mid, + Addr pc) { assert(size >= 0); _asid = asid; @@ -397,10 +397,8 @@ class Request assert(privateFlags.isSet(VALID_VADDR)); assert(privateFlags.noneSet(VALID_PADDR)); assert(split_addr > _vaddr && split_addr < _vaddr + _size); - req1 = new Request; - *req1 = *this; - req2 = new Request; - *req2 = *this; + req1 = new Request(*this); + req2 = new Request(*this); req1->_size = split_addr - _vaddr; req2->_vaddr = split_addr; req2->_size = _size - req1->_size; diff --git a/src/mem/ruby/system/CacheRecorder.cc b/src/mem/ruby/system/CacheRecorder.cc index 542d91aef..ab7d1cc91 100644 --- a/src/mem/ruby/system/CacheRecorder.cc +++ b/src/mem/ruby/system/CacheRecorder.cc @@ -109,21 +109,21 @@ CacheRecorder::enqueueNextFetchRequest() for (int rec_bytes_read = 0; rec_bytes_read < m_block_size_bytes; rec_bytes_read += RubySystem::getBlockSizeBytes()) { - Request* req = new Request(); + Request* req = nullptr; MemCmd::Command requestType; if (traceRecord->m_type == RubyRequestType_LD) { requestType = MemCmd::ReadReq; - req->setPhys(traceRecord->m_data_address + rec_bytes_read, + req = new Request(traceRecord->m_data_address + rec_bytes_read, RubySystem::getBlockSizeBytes(), 0, Request::funcMasterId); } else if (traceRecord->m_type == RubyRequestType_IFETCH) { requestType = MemCmd::ReadReq; - req->setPhys(traceRecord->m_data_address + rec_bytes_read, + req = new Request(traceRecord->m_data_address + rec_bytes_read, RubySystem::getBlockSizeBytes(), Request::INST_FETCH, Request::funcMasterId); } else { requestType = MemCmd::WriteReq; - req->setPhys(traceRecord->m_data_address + rec_bytes_read, + req = new Request(traceRecord->m_data_address + rec_bytes_read, RubySystem::getBlockSizeBytes(), 0, Request::funcMasterId); } |