diff options
author | Andreas Hansson <andreas.hansson@arm.com> | 2012-08-28 14:30:24 -0400 |
---|---|---|
committer | Andreas Hansson <andreas.hansson@arm.com> | 2012-08-28 14:30:24 -0400 |
commit | 105ad88d35003e00943c98aaea7d6ce163280a80 (patch) | |
tree | 4f350cafa9617141f045a8710910cc1136cb69ad | |
parent | d090f4d93016022a65e253e7c1637fb954e745ce (diff) | |
download | gem5-105ad88d35003e00943c98aaea7d6ce163280a80.tar.xz |
Checker: Fix checker CPU ports
This patch updates how the checker CPU handles the ports such that the
regressions will once again run without causing a panic.
A minor amount of tidying up was also done as part of this patch.
-rw-r--r-- | src/cpu/checker/cpu.cc | 5 | ||||
-rw-r--r-- | src/cpu/checker/cpu.hh | 35 |
2 files changed, 21 insertions, 19 deletions
diff --git a/src/cpu/checker/cpu.cc b/src/cpu/checker/cpu.cc index 73205dc35..3c1690ac3 100644 --- a/src/cpu/checker/cpu.cc +++ b/src/cpu/checker/cpu.cc @@ -65,7 +65,8 @@ CheckerCPU::init() } CheckerCPU::CheckerCPU(Params *p) - : BaseCPU(p, true), thread(NULL), tc(NULL) + : BaseCPU(p, true), systemPtr(NULL), icachePort(NULL), dcachePort(NULL), + tc(NULL), thread(NULL) { memReq = NULL; curStaticInst = NULL; @@ -83,9 +84,7 @@ CheckerCPU::CheckerCPU(Params *p) warnOnlyOnLoadError = p->warnOnlyOnLoadError; itb = p->itb; dtb = p->dtb; - systemPtr = NULL; workload = p->workload; - thread = NULL; updateOnError = true; } diff --git a/src/cpu/checker/cpu.hh b/src/cpu/checker/cpu.hh index 72dc2ce3e..6bd2b7e31 100644 --- a/src/cpu/checker/cpu.hh +++ b/src/cpu/checker/cpu.hh @@ -98,42 +98,40 @@ class CheckerCPU : public BaseCPU public: virtual void init(); - public: typedef CheckerCPUParams Params; - const Params *params() const - { return reinterpret_cast<const Params *>(_params); } CheckerCPU(Params *p); virtual ~CheckerCPU(); - std::vector<Process*> workload; - void setSystem(System *system); - System *systemPtr; - void setIcachePort(CpuPort *icache_port); - CpuPort *icachePort; - void setDcachePort(CpuPort *dcache_port); - CpuPort *dcachePort; - CpuPort &getDataPort() { - panic("Not supported on checker!"); + // the checker does not have ports on its own so return the + // data port of the actual CPU core + assert(dcachePort); return *dcachePort; } CpuPort &getInstPort() { - panic("Not supported on checker!"); + // the checker does not have ports on its own so return the + // data port of the actual CPU core + assert(icachePort); return *icachePort; } - public: - // Primary thread being run. - SimpleThread *thread; + protected: + + std::vector<Process*> workload; + + System *systemPtr; + + CpuPort *icachePort; + CpuPort *dcachePort; ThreadContext *tc; @@ -167,6 +165,11 @@ class CheckerCPU : public BaseCPU std::queue<int> miscRegIdxs; + public: + + // Primary thread being run. + SimpleThread *thread; + TheISA::TLB* getITBPtr() { return itb; } TheISA::TLB* getDTBPtr() { return dtb; } |