git-svn-id: https://www4.informatik.uni-erlangen.de/i4svn/danceos/trunk/devel/fail@1327 8c4709b5-6ec9-48aa-a5cd-a96041d1645a
89 lines
3.2 KiB
C++
89 lines
3.2 KiB
C++
#ifndef __TRACING_PLUGIN_HPP__
|
|
#define __TRACING_PLUGIN_HPP__
|
|
|
|
#include <ostream>
|
|
|
|
#include "util/MemoryMap.hpp"
|
|
#include "util/ProtoStream.hpp"
|
|
#include "efw/ExperimentFlow.hpp"
|
|
#include "config/FailConfig.hpp"
|
|
|
|
#include "../plugins/tracing/trace.pb.h"
|
|
|
|
// Check if configuration dependencies are satisfied:
|
|
#if !defined(CONFIG_EVENT_BREAKPOINTS) || !defined(CONFIG_EVENT_MEMREAD) || !defined(CONFIG_EVENT_MEMWRITE)
|
|
#warning The tracing plugin may (depending on its use) need breakpoints and/or read/write memory access events. Enable these in the cmake configuration tool.
|
|
#endif
|
|
|
|
/**
|
|
* \class TracingPlugin
|
|
*
|
|
* \brief Plugin to record instruction traces and memory accesses.
|
|
*
|
|
* This plugin is supposed to be instantiated, configured and run by
|
|
* experiments needing instruction or memory access traces. Tracing can be
|
|
* restricted to a memory or instruction address map; the restrictions are
|
|
* applied together, i.e., a memory access is only logged if neither its
|
|
* instruction address nor its memory address is restricted.
|
|
*
|
|
* TODO: document usage by example
|
|
* FIXME: handle configuration changes after tracing start properly
|
|
* FIXME: more explicit startup/shutdown; listener-based event interface needed?
|
|
* -> should simulator.removeFlow make sure all remaining active events
|
|
* are delivered?
|
|
* FIXME: trace a sequence of pb messages, not a giant single one (pb weren't
|
|
* made for huge messages)
|
|
* FIXME: destructor -> removeFlow?
|
|
*/
|
|
class TracingPlugin : public fail::ExperimentFlow
|
|
{
|
|
private:
|
|
fail::MemoryMap *m_memMap; //!< address restriction for memory accesses
|
|
fail::MemoryMap *m_ipMap; //!< instruction address restriction
|
|
bool m_memonly; //!< log instructions only if they are memory accesses
|
|
bool m_iponly; //!< log instruction addresses only
|
|
|
|
std::ostream *m_protoStreamFile;
|
|
std::ostream *m_os; //!< ostream to write human-readable trace into
|
|
fail::ProtoOStream *ps;
|
|
|
|
public:
|
|
TracingPlugin()
|
|
: m_memMap(0), m_ipMap(0), m_memonly(false), m_iponly(false),
|
|
m_protoStreamFile(0), m_os(0) { }
|
|
bool run();
|
|
/**
|
|
* Restricts tracing to memory addresses listed in this MemoryMap. An
|
|
* access wider than 8 bit *is* logged if *one* of the bytes it
|
|
* reads/writes is listed.
|
|
*/
|
|
void restrictMemoryAddresses(fail::MemoryMap *mm) { m_memMap = mm; }
|
|
/**
|
|
* Restricts tracing to instruction addresses listed in this MemoryMap.
|
|
* This restriction currently silently assumes instructions are only
|
|
* one byte wide; make sure your memory map covers this first byte of
|
|
* the instructions you want to trace.
|
|
*/
|
|
void restrictInstructionAddresses(fail::MemoryMap *mm) { m_ipMap = mm; }
|
|
/**
|
|
* If invoked with memonly=true, instructions are only logged if they
|
|
* conducted a memory access. Defaults to false: All instructions are
|
|
* logged.
|
|
*/
|
|
void setLogMemOnly(bool memonly) { m_memonly = memonly; }
|
|
/**
|
|
* If invoked with iponly=true, only instruction addresses are logged.
|
|
*/
|
|
void setLogIPOnly(bool iponly) { m_iponly = iponly; }
|
|
/**
|
|
* ostream to trace into (human-readable)
|
|
*/
|
|
void setOstream(std::ostream *os) { m_os = os; }
|
|
/**
|
|
* ProtoStream file to trace into (trace.proto instance)
|
|
*/
|
|
void setTraceFile(std::ostream *os) { m_protoStreamFile = os; }
|
|
};
|
|
|
|
#endif // __TRACING_PLUGIN_HPP__
|