Contemporary AspectC++ versions can deal with the LLVM headers very well, and #ifdef __puma stuff in Fail* headers results in unmaintainable #ifdef __puma blocks in other parts of Fail* (e.g., the trace importer). Make sure you're using a 64-bit ac++ when living in a 64-bit userland (the 32-bit version doesn't know about __int128), and be aware that AspectC++ r325 introduced a regression that has not been fixed yet. Change-Id: I5bb759b08995a74b020d44a2b40e9d7a6e18111c
45 lines
1.2 KiB
C++
45 lines
1.2 KiB
C++
#ifndef __REGISTER_IMPORTER_H__
|
|
#define __REGISTER_IMPORTER_H__
|
|
|
|
|
|
#include "util/CommandLine.hpp"
|
|
#include "Importer.hpp"
|
|
|
|
#include "util/llvmdisassembler/LLVMDisassembler.hpp"
|
|
|
|
|
|
class RegisterImporter : public Importer {
|
|
llvm::OwningPtr<llvm::object::Binary> binary;
|
|
llvm::OwningPtr<fail::LLVMDisassembler> disas;
|
|
|
|
bool addRegisterTrace(fail::simtime_t curtime, instruction_count_t instr,
|
|
const Trace_Event &ev,
|
|
const fail::LLVMtoFailTranslator::reginfo_t &info,
|
|
char access_type);
|
|
|
|
fail::CommandLine::option_handle NO_GP, FLAGS, IP;
|
|
bool do_gp, do_flags, do_ip;
|
|
|
|
public:
|
|
RegisterImporter() : Importer(), do_gp(true), do_flags(false), do_ip(false) {}
|
|
/**
|
|
* Callback function that can be used to add command line options
|
|
* to the cmd interface
|
|
*/
|
|
virtual bool cb_commandline_init();
|
|
|
|
virtual bool handle_ip_event(fail::simtime_t curtime, instruction_count_t instr,
|
|
const Trace_Event &ev);
|
|
virtual bool handle_mem_event(fail::simtime_t curtime, instruction_count_t instr,
|
|
const Trace_Event &ev) {
|
|
/* ignore on purpose */
|
|
return true;
|
|
}
|
|
|
|
virtual void open_unused_ec_intervals() {
|
|
/* empty, Memory Map has a different meaning in this importer */
|
|
}
|
|
};
|
|
|
|
#endif
|