diff options
author | Radhika Jagtap <radhika.jagtap@ARM.com> | 2015-12-07 16:42:16 -0600 |
---|---|---|
committer | Radhika Jagtap <radhika.jagtap@ARM.com> | 2015-12-07 16:42:16 -0600 |
commit | 54519fd51f739c3a37c4ad712b86a353eabbbfec (patch) | |
tree | 21002ebffe820d302b839ac625636830b141964b /src/cpu/trace | |
parent | 3080bbcc365e6ed663787a4c06cd2b7c4a118d47 (diff) | |
download | gem5-54519fd51f739c3a37c4ad712b86a353eabbbfec.tar.xz |
cpu: Support virtual addr in elastic traces
This patch adds support to optionally capture the virtual address and asid
for load/store instructions in the elastic traces. If they are present in
the traces, Trace CPU will set those fields of the request during replay.
Diffstat (limited to 'src/cpu/trace')
-rw-r--r-- | src/cpu/trace/trace_cpu.cc | 38 | ||||
-rw-r--r-- | src/cpu/trace/trace_cpu.hh | 8 |
2 files changed, 36 insertions, 10 deletions
diff --git a/src/cpu/trace/trace_cpu.cc b/src/cpu/trace/trace_cpu.cc index ffa64014a..f940be2f9 100644 --- a/src/cpu/trace/trace_cpu.cc +++ b/src/cpu/trace/trace_cpu.cc @@ -597,8 +597,9 @@ PacketPtr TraceCPU::ElasticDataGen::executeMemReq(GraphNode* node_ptr) { - DPRINTF(TraceCPUData, "Executing memory request %lli (addr %d, pc %#x, " - "size %d, flags %d).\n", node_ptr->seqNum, node_ptr->addr, + DPRINTF(TraceCPUData, "Executing memory request %lli (phys addr %d, " + "virt addr %d, pc %#x, size %d, flags %d).\n", + node_ptr->seqNum, node_ptr->physAddr, node_ptr->virtAddr, node_ptr->pc, node_ptr->size, node_ptr->flags); // If the request is strictly ordered, do not send it. Just return nullptr @@ -617,17 +618,26 @@ TraceCPU::ElasticDataGen::executeMemReq(GraphNode* node_ptr) // happens. If required the code could be revised to mimick splitting such // a request into two. unsigned blk_size = owner.cacheLineSize(); - Addr blk_offset = (node_ptr->addr & (Addr)(blk_size - 1)); + Addr blk_offset = (node_ptr->physAddr & (Addr)(blk_size - 1)); if (!(blk_offset + node_ptr->size <= blk_size)) { node_ptr->size = blk_size - blk_offset; ++numSplitReqs; } // Create a request and the packet containing request - Request* req = new Request(node_ptr->addr, node_ptr->size, node_ptr->flags, - masterID, node_ptr->seqNum, + Request* req = new Request(node_ptr->physAddr, node_ptr->size, + node_ptr->flags, masterID, node_ptr->seqNum, ContextID(0), ThreadID(0)); req->setPC(node_ptr->pc); + // If virtual address is valid, set the asid and virtual address fields + // of the request. + if (node_ptr->virtAddr != 0) { + req->setVirt(node_ptr->asid, node_ptr->virtAddr, node_ptr->size, + node_ptr->flags, masterID, node_ptr->pc); + req->setPaddr(node_ptr->physAddr); + req->setReqInstSeqNum(node_ptr->seqNum); + } + PacketPtr pkt; uint8_t* pkt_data = new uint8_t[req->getSize()]; if (node_ptr->isLoad()) { @@ -1277,10 +1287,20 @@ TraceCPU::ElasticDataGen::InputStream::read(GraphNode* element) } // Optional fields - if (pkt_msg.has_addr()) - element->addr = pkt_msg.addr(); + if (pkt_msg.has_p_addr()) + element->physAddr = pkt_msg.p_addr(); + else + element->physAddr = 0; + + if (pkt_msg.has_v_addr()) + element->virtAddr = pkt_msg.v_addr(); + else + element->virtAddr = 0; + + if (pkt_msg.has_asid()) + element->asid = pkt_msg.asid(); else - element->addr = 0; + element->asid = 0; if (pkt_msg.has_size()) element->size = pkt_msg.size(); @@ -1383,7 +1403,7 @@ TraceCPU::ElasticDataGen::GraphNode::writeElementAsTrace() const DPRINTFR(TraceCPUData, "%lli", seqNum); DPRINTFR(TraceCPUData, ",%s", typeToStr()); if (isLoad() || isStore()) { - DPRINTFR(TraceCPUData, ",%i", addr); + DPRINTFR(TraceCPUData, ",%i", physAddr); DPRINTFR(TraceCPUData, ",%i", size); DPRINTFR(TraceCPUData, ",%i", flags); } diff --git a/src/cpu/trace/trace_cpu.hh b/src/cpu/trace/trace_cpu.hh index 751321491..bb59c3fab 100644 --- a/src/cpu/trace/trace_cpu.hh +++ b/src/cpu/trace/trace_cpu.hh @@ -596,7 +596,13 @@ class TraceCPU : public BaseCPU RecordType type; /** The address for the request if any */ - Addr addr; + Addr physAddr; + + /** The virtual address for the request if any */ + Addr virtAddr; + + /** The address space id which is set if the virtual address is set */ + uint32_t asid; /** Size of request if any */ uint32_t size; |