Fail* directories reorganized, Code-cleanup (-> coding-style), Typos+comments fixed.
git-svn-id: https://www4.informatik.uni-erlangen.de/i4svn/danceos/trunk/devel/fail@1321 8c4709b5-6ec9-48aa-a5cd-a96041d1645a
This commit is contained in:
77
src/plugins/tracing/TracingPlugin.cc
Normal file
77
src/plugins/tracing/TracingPlugin.cc
Normal file
@ -0,0 +1,77 @@
|
||||
#include <iostream>
|
||||
|
||||
#include "sal/SALInst.hpp"
|
||||
#include "sal/Register.hpp"
|
||||
#include "TracingPlugin.hpp"
|
||||
|
||||
using namespace std;
|
||||
using namespace fail;
|
||||
|
||||
bool TracingPlugin::run()
|
||||
{
|
||||
MemAccessEvent ev_mem(ANY_ADDR);
|
||||
BPSingleEvent ev_step(ANY_ADDR);
|
||||
BaseEvent *ev;
|
||||
|
||||
if (m_iponly || !m_memonly) {
|
||||
simulator.addEvent(&ev_step);
|
||||
}
|
||||
if (m_memonly || !m_iponly) {
|
||||
simulator.addEvent(&ev_mem);
|
||||
}
|
||||
if(m_protoStreamFile) {
|
||||
ps = new ProtoOStream(m_protoStreamFile);
|
||||
}
|
||||
|
||||
while (true) {
|
||||
ev = simulator.waitAny();
|
||||
|
||||
if (ev == &ev_step) {
|
||||
simulator.addEvent(&ev_step);
|
||||
|
||||
address_t ip = ev_step.getTriggerInstructionPointer();
|
||||
if (m_ipMap && !m_ipMap->isMatching(ip)) {
|
||||
continue;
|
||||
}
|
||||
|
||||
if (m_os)
|
||||
*m_os << "[Tracing] IP " << hex << ip << "\n";
|
||||
if (m_protoStreamFile) {
|
||||
Trace_Event e;
|
||||
e.set_ip(ip);
|
||||
ps->writeMessage(&e);
|
||||
}
|
||||
} else if (ev == &ev_mem) {
|
||||
simulator.addEvent(&ev_mem);
|
||||
|
||||
address_t ip = ev_mem.getTriggerInstructionPointer();
|
||||
address_t addr = ev_mem.getTriggerAddress();
|
||||
size_t width = ev_mem.getTriggerWidth();
|
||||
if ((m_ipMap && !m_ipMap->isMatching(ip)) ||
|
||||
(m_memMap && !m_memMap->isMatching(addr, width))) {
|
||||
continue;
|
||||
}
|
||||
|
||||
if (m_os)
|
||||
*m_os << hex << "[Tracing] MEM "
|
||||
<< ((ev_mem.getTriggerAccessType() &
|
||||
MemAccessEvent::MEM_READ) ? "R " : "W ")
|
||||
<< addr << " width " << width << " IP " << ip << "\n";
|
||||
if (m_protoStreamFile) {
|
||||
Trace_Event e;
|
||||
e.set_ip(ip);
|
||||
e.set_memaddr(addr);
|
||||
e.set_width(width);
|
||||
e.set_accesstype(
|
||||
(ev_mem.getTriggerAccessType() & MemAccessEvent::MEM_READ) ?
|
||||
e.READ : e.WRITE);
|
||||
ps->writeMessage(&e);
|
||||
}
|
||||
} else {
|
||||
if (m_os)
|
||||
*m_os << "[Tracing] SOMETHING IS SERIOUSLY WRONG\n";
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
Reference in New Issue
Block a user