ecos: campaign rewritten
git-svn-id: https://www4.informatik.uni-erlangen.de/i4svn/danceos/trunk/devel/fail@1920 8c4709b5-6ec9-48aa-a5cd-a96041d1645a
This commit is contained in:
@ -1,11 +1,13 @@
|
||||
#pragma once
|
||||
|
||||
#include <string>
|
||||
#include <fstream>
|
||||
|
||||
#include "cpn/Campaign.hpp"
|
||||
#include "comm/ExperimentData.hpp"
|
||||
#include "ecos_kernel_test.pb.h"
|
||||
#include "util/MemoryMap.hpp"
|
||||
#include "util/Logger.hpp"
|
||||
|
||||
class EcosKernelTestExperimentData : public fail::ExperimentData {
|
||||
public:
|
||||
@ -17,7 +19,25 @@ class EcosKernelTestCampaign : public fail::Campaign {
|
||||
static const std::string dir_images;
|
||||
static const std::string dir_prerequisites;
|
||||
static const std::string dir_results;
|
||||
fail::Logger m_log;
|
||||
int count_exp, count_exp_jobs;
|
||||
int count_known, count_known_jobs;
|
||||
bool add_experiment_ec(const std::string& variant, const std::string& benchmark,
|
||||
fail::address_t data_address, int instr1, int instr2, fail::address_t instr_absolute);
|
||||
bool add_known_ec(const std::string& variant, const std::string& benchmark,
|
||||
fail::address_t data_address, int instr1, int instr2, fail::address_t instr_absolute);
|
||||
bool init_results();
|
||||
void add_result(const std::string& variant, const std::string& benchmark,
|
||||
int instr1, int instr2, fail::address_t instr2_absolute, fail::address_t ec_data_address,
|
||||
int bitnr, int bit_width, int resulttype, int ecos_test_result, fail::address_t latest_ip,
|
||||
int error_corrected, const std::string& details);
|
||||
void finalize_results();
|
||||
bool check_available(fail::address_t data_address, int instr2);
|
||||
std::ofstream resultstream;
|
||||
std::map<std::pair<unsigned, int>, uint64_t> available_results;
|
||||
public:
|
||||
EcosKernelTestCampaign() : m_log("EcosKernelTest Campaign"),
|
||||
count_exp(0), count_exp_jobs(0), count_known(0), count_known_jobs(0) {}
|
||||
virtual bool run();
|
||||
static bool readMemoryMap(fail::MemoryMap &mm, char const * const filename);
|
||||
static bool writeTraceInfo(unsigned instr_counter, unsigned timeout, unsigned lowest_addr, unsigned highest_addr);
|
||||
@ -26,6 +46,6 @@ public:
|
||||
static std::string filename_state(const std::string& variant = "", const std::string& benchmark = "");
|
||||
static std::string filename_trace(const std::string& variant = "", const std::string& benchmark = "");
|
||||
static std::string filename_traceinfo(const std::string& variant = "", const std::string& benchmark = "");
|
||||
static std::string filename_results(const std::string& variant, const std::string& benchmark);
|
||||
static std::string filename_results(const std::string& variant = "", const std::string& benchmark = "");
|
||||
static std::string filename_elf(const std::string& variant = "", const std::string& benchmark = "");
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user