Go to the documentation of this file.
47 #include "debug/Checkpoint.hh"
48 #include "debug/RiscvMisc.hh"
49 #include "params/RiscvISA.hh"
58 GEM5_VAR_USED
const std::array<const char *, NUM_MISCREGS>
MiscRegNames = {{
236 if (hpmcounter < 0 || hpmcounter > 31)
237 panic(
"Illegal HPM counter %d\n", hpmcounter);
252 return (
miscRegFile[counteren] & (1ULL << (hpmcounter))) > 0;
260 panic(
"Illegal CSR index %#x\n", misc_reg);
263 DPRINTF(RiscvMisc,
"Reading MiscReg %s (%d): %#x.\n",
276 DPRINTF(RiscvMisc,
"Cycle counter at: %llu.\n",
280 warn(
"Cycle counter disabled.\n");
285 DPRINTF(RiscvMisc,
"Wall-clock counter at: %llu.\n",
289 warn(
"Wall clock disabled.\n");
294 DPRINTF(RiscvMisc,
"Instruction counter at: %llu.\n",
298 warn(
"Instruction counter disabled.\n");
331 DPRINTF(RiscvMisc,
"HPM counter %d: %llu.\n",
348 panic(
"Illegal CSR index %#x\n", misc_reg);
350 DPRINTF(RiscvMisc,
"Setting MiscReg %s (%d) to %#x.\n",
360 warn(
"Ignoring write to %s.\n",
CSRData.at(misc_reg).name);
382 for (
int i=0;
i <
sizeof(
val);
i++) {
384 uint8_t cfg_val = (
val >> (8*
i)) & 0xff;
394 mmu->getPMP()->pmpUpdateCfg(pmp_index,cfg_val);
408 mmu->getPMP()->pmpUpdateAddr(pmp_index,
val);
434 if (new_val.mode != AddrXlateMode::BARE &&
435 new_val.mode != AddrXlateMode::SV39)
436 new_val.mode = cur_val.mode;
476 DPRINTF(Checkpoint,
"Serializing Riscv Misc Registers\n");
483 DPRINTF(Checkpoint,
"Unserializing Riscv Misc Registers\n");
virtual void setIntReg(RegIndex reg_idx, RegVal val)=0
const std::map< int, CSRMetadata > CSRData
Cycles curCycle() const
Determine the current cycle, corresponding to a tick aligned to a clock edge.
virtual RegVal readFloatReg(RegIndex reg_idx) const =0
BaseInterrupts * getInterruptController(ThreadID tid)
#define UNSERIALIZE_CONTAINER(member)
void copyRegsFrom(ThreadContext *src) override
virtual BaseMMU * getMMUPtr()=0
virtual ContextID contextId() const =0
constexpr T mbits(T val, unsigned first, unsigned last)
Mask off the given bits in place like bits() but without shifting.
virtual Counter totalInsts() const =0
const RegVal STATUS_UXL_MASK
RegVal readMiscReg(int misc_reg)
ThreadContext is the external interface to all thread state for anything outside of the CPU.
const GEM5_VAR_USED std::array< const char *, NUM_MISCREGS > MiscRegNames
void unserialize(CheckpointIn &cp) override
Unserialize an object.
const RegVal STATUS_SXL_MASK
RegVal readMiscRegNoEffect(int misc_reg) const
constexpr T bits(T val, unsigned first, unsigned last)
Extract the bitfield from position 'first' to 'last' (inclusive) from 'val' and right justify it.
virtual void setFloatReg(RegIndex reg_idx, RegVal val)=0
std::vector< RegVal > miscRegFile
virtual TheISA::PCState pcState() const =0
virtual RegVal readIntReg(RegIndex reg_idx) const =0
void serialize(CheckpointOut &cp) const override
Serialize an object.
#define SERIALIZE_CONTAINER(member)
std::ostream CheckpointOut
void setMiscReg(int misc_reg, RegVal val)
virtual BaseCPU * getCpuPtr()=0
virtual int threadId() const =0
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
const RegVal ISA_EXT_C_MASK
bool hpmCounterEnabled(int counter) const
#define panic(...)
This implements a cprintf based panic() function.
void setMiscRegNoEffect(int misc_reg, RegVal val)
Generated on Tue Sep 7 2021 14:53:39 for gem5 by doxygen 1.8.17