Go to the documentation of this file.
36 #include "debug/Quiesce.hh"
37 #include "debug/Timer.hh"
59 for (
int bit = 15; bit > 0; --bit) {
68 static inline std::string
72 {
"asi",
"tick",
"fprs",
"pcr",
"pic",
73 "gsr",
"softint_set",
"softint_clr",
"softint",
"tick_cmpr",
74 "stick",
"stick_cmpr",
75 "tpc",
"tnpc",
"tstate",
"tt",
"privtick",
"tba",
"pstate",
"tl",
78 "hpstate",
"htstate",
"hintp",
"htba",
"hver",
"strand_sts_reg",
80 "fsr",
"prictx",
"secctx",
"partId",
"lsuCtrlReg",
81 "scratch0",
"scratch1",
"scratch2",
"scratch3",
"scratch4",
82 "scratch5",
"scratch6",
"scratch7",
"cpuMondoHead",
"cpuMondoTail",
83 "devMondoHead",
"devMondoTail",
"resErrorHead",
"resErrorTail",
84 "nresErrorHead",
"nresErrorTail",
"TlbData" };
117 DPRINTF(Timer,
"writing to TICK compare register value %#X\n",
val);
133 DPRINTF(Timer,
"writing to sTICK compare register value %#X\n",
val);
146 panic(
"Shouldn't be writing HVER\n");
204 DPRINTF(Timer,
"writing to hsTICK compare register value %#X\n",
val);
209 HPSTATE newVal =
val;
214 if (newVal.tlz &&
tl == 0 && !newVal.hpriv)
226 panic(
"No support for setting spec_en bit\n");
229 DPRINTF(Quiesce,
"Cpu executed quiescing instruction\n");
239 panic(
"Invalid write to FS misc register %s\n",
273 return ULL(0x3e) << 48 |
292 for (
x =
tc->
contextId() & ~3; x < sys->threads.size();
x++) {
293 switch (sys->
threads[
x]->status()) {
295 temp |= STS::st_run << (STS::shft_fsm0 -
296 ((
x & 0x3) * (STS::shft_fsm0-STS::shft_fsm1)));
300 temp |= STS::st_idle << (STS::shft_fsm0 -
301 ((
x & 0x3) * (STS::shft_fsm0-STS::shft_fsm1)));
304 temp |= STS::st_halt << (STS::shft_fsm0 -
305 ((
x & 0x3) * (STS::shft_fsm0-STS::shft_fsm1)));
308 panic(
"What state are we in?!\n");
314 panic(
"Invalid read to FS misc register\n");
321 panic(
"tick compare not implemented\n");
335 assert(delay >= 0 &&
"stick compare missed interrupt cycle");
338 DPRINTF(Timer,
"STick compare cycle reached at %#x\n",
362 assert(delay >= 0 &&
"hstick compare missed interrupt cycle");
365 DPRINTF(Timer,
"HSTick compare cycle reached at %#x\n",
virtual RegVal readMiscRegNoEffect(RegIndex misc_reg) const =0
bool scheduled() const
Determine if the current event is scheduled.
@ MISCREG_QUEUE_CPU_MONDO_TAIL
STickCompareEvent * sTickCompare
EventWrapper< ISA, &ISA::processSTickCompare > STickCompareEvent
virtual void suspend()=0
Set the status to Suspended.
void processSTickCompare()
void postInterrupt(ThreadID tid, int int_num, int index)
void deschedule(Event &event)
@ MISCREG_QUEUE_DEV_MONDO_HEAD
const char *const miscRegName[]
void setFSReg(int miscReg, RegVal val)
@ MISCREG_QUEUE_DEV_MONDO_TAIL
void processHSTickCompare()
HPSTATE hpstate
Hyperprivileged Registers.
RegVal readMiscRegNoEffect(int miscReg) const
void schedule(Event &event, Tick when)
void setMiscRegNoEffect(int miscReg, RegVal val)
Workload * workload
OS kernel.
@ MISCREG_QUEUE_NRES_ERROR_TAIL
@ Halted
Permanently shut down.
Tick clockEdge(Cycles cycles=Cycles(0)) const
Determine the tick when a cycle begins, by default the current one, but the argument also enables the...
void clearInterrupt(ThreadID tid, int int_num, int index)
@ MISCREG_QUEUE_CPU_MONDO_HEAD
virtual ContextID contextId() const =0
@ MISCREG_QUEUE_RES_ERROR_HEAD
virtual Status status() const =0
void setMiscReg(int miscReg, RegVal val)
@ MISCREG_HPSTATE
Hyper privileged registers.
@ Suspended
Temporarily inactive.
static std::string getMiscRegName(RegIndex index)
void processTickCompare()
Process a tick compare event and generate an interrupt on the cpu if appropriate.
@ MISCREG_QUEUE_NRES_ERROR_HEAD
@ MISCREG_QUEUE_RES_ERROR_TAIL
Cycles is a wrapper class for representing cycle counts, i.e.
constexpr T bits(T val, unsigned first, unsigned last)
Extract the bitfield from position 'first' to 'last' (inclusive) from 'val' and right justify it.
HSTickCompareEvent * hSTickCompare
TickCompareEvent * tickCompare
EventWrapper< ISA, &ISA::processTickCompare > TickCompareEvent
RegVal readFSReg(int miscReg)
EventWrapper< ISA, &ISA::processHSTickCompare > HSTickCompareEvent
virtual BaseCPU * getCpuPtr()=0
#define ULL(N)
uint64_t constant
virtual System * getSystemPtr()=0
#define panic(...)
This implements a cprintf based panic() function.
Generated on Tue Jun 22 2021 15:28:25 for gem5 by doxygen 1.8.17