From 89be91cec3677f3f1143972de7ca85e2dc33dbff Mon Sep 17 00:00:00 2001 From: Mike Frysinger Date: Fri, 5 Jun 2015 21:06:52 +0800 Subject: [PATCH] unify interactive core processing Different functions in here process the core argument in different ways. Unify all of them with a utility function. --- riscv/interactive.cc | 38 ++++++++++++++++++++------------------ riscv/sim.h | 1 + 2 files changed, 21 insertions(+), 18 deletions(-) diff --git a/riscv/interactive.cc b/riscv/interactive.cc index 8e58411..c4eb869 100644 --- a/riscv/interactive.cc +++ b/riscv/interactive.cc @@ -18,6 +18,15 @@ #include #include +processor_t *sim_t::get_core(const std::string& i) +{ + char *ptr; + unsigned long p = strtoul(i.c_str(), &ptr, 10); + if (*ptr || p >= num_cores()) + throw trap_illegal_instruction(); + return get_core(p); +} + static std::string readline(int fd) { struct termios tios; @@ -150,11 +159,8 @@ reg_t sim_t::get_pc(const std::vector& args) if(args.size() != 1) throw trap_illegal_instruction(); - int p = atoi(args[0].c_str()); - if(p >= (int)num_cores()) - throw trap_illegal_instruction(); - - return procs[p]->state.pc; + processor_t *p = get_core(args[0]); + return p->state.pc; } reg_t sim_t::get_reg(const std::vector& args) @@ -162,16 +168,14 @@ reg_t sim_t::get_reg(const std::vector& args) if(args.size() != 2) throw trap_illegal_instruction(); - char* ptr; - unsigned long p = strtoul(args[0].c_str(), &ptr, 10); - if (*ptr || p >= num_cores()) - throw trap_illegal_instruction(); + processor_t *p = get_core(args[0]); unsigned long r = std::find(xpr_name, xpr_name + NXPR, args[1]) - xpr_name; if (r == NXPR) { + char *ptr; r = strtoul(args[1].c_str(), &ptr, 10); if (*ptr) { - #define DECLARE_CSR(name, number) if (args[1] == #name) return procs[p]->get_csr(number); + #define DECLARE_CSR(name, number) if (args[1] == #name) return p->get_csr(number); if (0) ; #include "encoding.h" else r = NXPR; @@ -182,7 +186,7 @@ reg_t sim_t::get_reg(const std::vector& args) if (r >= NXPR) throw trap_illegal_instruction(); - return procs[p]->state.XPR[r]; + return p->state.XPR[r]; } reg_t sim_t::get_freg(const std::vector& args) @@ -190,14 +194,14 @@ reg_t sim_t::get_freg(const std::vector& args) if(args.size() != 2) throw trap_illegal_instruction(); - int p = atoi(args[0].c_str()); + processor_t *p = get_core(args[0]); int r = std::find(fpr_name, fpr_name + NFPR, args[1]) - fpr_name; if (r == NFPR) r = atoi(args[1].c_str()); - if(p >= (int)num_cores() || r >= NFPR) + if (r >= NFPR) throw trap_illegal_instruction(); - return procs[p]->state.FPR[r]; + return p->state.FPR[r]; } void sim_t::interactive_reg(const std::string& cmd, const std::vector& args) @@ -235,10 +239,8 @@ reg_t sim_t::get_mem(const std::vector& args) mmu_t* mmu = debug_mmu; if(args.size() == 2) { - int p = atoi(args[0].c_str()); - if(p >= (int)num_cores()) - throw trap_illegal_instruction(); - mmu = procs[p]->get_mmu(); + processor_t *p = get_core(args[0]); + mmu = p->get_mmu(); addr_str = args[1]; } diff --git a/riscv/sim.h b/riscv/sim.h index 9b8f6e0..8f7718a 100644 --- a/riscv/sim.h +++ b/riscv/sim.h @@ -45,6 +45,7 @@ private: mmu_t* debug_mmu; // debug port into main memory std::vector procs; + processor_t* get_core(const std::string& i); void step(size_t n); // step through simulation static const size_t INTERLEAVE = 5000; static const size_t INSNS_PER_RTC_TICK = 100; // 10 MHz clock for 1 BIPS core -- 2.30.2