git-svn-id: https://www4.informatik.uni-erlangen.de/i4svn/danceos/trunk/devel/fail@1245 8c4709b5-6ec9-48aa-a5cd-a96041d1645a
44 lines
1.1 KiB
C++
44 lines
1.1 KiB
C++
#include "experiment.hpp"
|
|
#include "MHTestCampaign.hpp"
|
|
#include "SAL/SALInst.hpp"
|
|
#include "SAL/Register.hpp"
|
|
#include "controller/Event.hpp"
|
|
|
|
#include <iostream>
|
|
|
|
bool MHTestExperiment::run()
|
|
{
|
|
|
|
cout << "[MHTestExperiment] Let's go" << endl;
|
|
#if 0
|
|
fi::BPEvent mainbp(0x00003c34);
|
|
sal::simulator.addEventAndWait(&mainbp);
|
|
cout << "[MHTestExperiment] breakpoint reached, saving" << endl;
|
|
sal::simulator.save("hello.main");
|
|
#else
|
|
MHExperimentData par;
|
|
if(m_jc.getParam(par)){
|
|
|
|
int num = par.msg.input();
|
|
cout << "[MHExperiment] stepping " << num << " instructions" << endl;
|
|
if (num > 0) {
|
|
fi::BPEvent nextbp(fi::ANY_ADDR);
|
|
nextbp.setCounter(num);
|
|
sal::simulator.addEventAndWait(&nextbp);
|
|
}
|
|
sal::address_t instr = sal::simulator.getRegisterManager().getInstructionPointer();
|
|
cout << "[MHTestExperiment] Reached instruction: "
|
|
<< hex << instr
|
|
<< endl;
|
|
par.msg.set_output(instr);
|
|
m_jc.sendResult(par);
|
|
} else {
|
|
cout << "No data for me? :(" << endl;
|
|
}
|
|
#endif
|
|
sal::simulator.clearEvents(this);
|
|
sal::simulator.terminate();
|
|
return true;
|
|
}
|
|
|