Go to the documentation of this file.
36 #include "debug/Quiesce.hh"
37 #include "debug/Timer.hh"
43 using namespace SparcISA;
62 for (
int bit = 15; bit > 0; --bit) {
71 static inline std::string
75 {
"asi",
"tick",
"fprs",
"pcr",
"pic",
76 "gsr",
"softint_set",
"softint_clr",
"softint",
"tick_cmpr",
77 "stick",
"stick_cmpr",
78 "tpc",
"tnpc",
"tstate",
"tt",
"privtick",
"tba",
"pstate",
"tl",
81 "hpstate",
"htstate",
"hintp",
"htba",
"hver",
"strand_sts_reg",
83 "fsr",
"prictx",
"secctx",
"partId",
"lsuCtrlReg",
84 "scratch0",
"scratch1",
"scratch2",
"scratch3",
"scratch4",
85 "scratch5",
"scratch6",
"scratch7",
"cpuMondoHead",
"cpuMondoTail",
86 "devMondoHead",
"devMondoTail",
"resErrorHead",
"resErrorTail",
87 "nresErrorHead",
"nresErrorTail",
"TlbData" };
120 DPRINTF(Timer,
"writing to TICK compare register value %#X\n",
val);
136 DPRINTF(Timer,
"writing to sTICK compare register value %#X\n",
val);
149 panic(
"Shouldn't be writing HVER\n");
156 cpu->clearInterrupt(0,
IT_HINTP, 0);
207 DPRINTF(Timer,
"writing to hsTICK compare register value %#X\n",
val);
212 HPSTATE newVal =
val;
217 if (newVal.tlz &&
tl == 0 && !newVal.hpriv)
229 panic(
"No support for setting spec_en bit\n");
232 DPRINTF(Quiesce,
"Cpu executed quiescing instruction\n");
242 panic(
"Invalid write to FS misc register %s\n",
276 return 0x3eULL << 48 |
295 for (
x =
tc->
contextId() & ~3; x < sys->threads.size();
x++) {
296 switch (sys->
threads[
x]->status()) {
298 temp |= STS::st_run << (STS::shft_fsm0 -
299 ((
x & 0x3) * (STS::shft_fsm0-STS::shft_fsm1)));
303 temp |= STS::st_idle << (STS::shft_fsm0 -
304 ((
x & 0x3) * (STS::shft_fsm0-STS::shft_fsm1)));
307 temp |= STS::st_halt << (STS::shft_fsm0 -
308 ((
x & 0x3) * (STS::shft_fsm0-STS::shft_fsm1)));
311 panic(
"What state are we in?!\n");
317 panic(
"Invalid read to FS misc register\n");
324 panic(
"tick compare not implemented\n");
338 assert(delay >= 0 &&
"stick compare missed interrupt cycle");
341 DPRINTF(Timer,
"STick compare cycle reached at %#x\n",
365 assert(delay >= 0 &&
"hstick compare missed interrupt cycle");
368 DPRINTF(Timer,
"HSTick compare cycle reached at %#x\n",
void processTickCompare()
Process a tick compare event and generate an interrupt on the cpu if appropriate.
virtual System * getSystemPtr()=0
EventWrapper< ISA, &ISA::processHSTickCompare > HSTickCompareEvent
@ Halted
Permanently shut down.
static std::string getMiscRegName(RegIndex index)
void processHSTickCompare()
void setFSReg(int miscReg, RegVal val)
@ MISCREG_QUEUE_DEV_MONDO_HEAD
HSTickCompareEvent * hSTickCompare
@ MISCREG_QUEUE_NRES_ERROR_HEAD
RegVal readFSReg(int miscReg)
const char *const miscRegName[]
virtual ContextID contextId() const =0
Workload * workload
OS kernel.
@ MISCREG_HPSTATE
Hyper privileged registers.
virtual Status status() const =0
constexpr uint64_t mask(unsigned nbits)
Generate a 64-bit mask of 'nbits' 1s, right justified.
Cycles is a wrapper class for representing cycle counts, i.e.
EventWrapper< ISA, &ISA::processSTickCompare > STickCompareEvent
EventWrapper< ISA, &ISA::processTickCompare > TickCompareEvent
@ Suspended
Temporarily inactive.
void setMiscRegNoEffect(int miscReg, RegVal val)
@ MISCREG_QUEUE_DEV_MONDO_TAIL
@ MISCREG_QUEUE_CPU_MONDO_TAIL
TickCompareEvent * tickCompare
@ MISCREG_QUEUE_RES_ERROR_HEAD
constexpr T bits(T val, unsigned first, unsigned last)
Extract the bitfield from position 'first' to 'last' (inclusive) from 'val' and right justify it.
void processSTickCompare()
HPSTATE hpstate
Hyperprivileged Registers.
virtual RegVal readMiscRegNoEffect(RegIndex misc_reg) const =0
RegVal readMiscRegNoEffect(int miscReg) const
@ MISCREG_QUEUE_CPU_MONDO_HEAD
@ MISCREG_QUEUE_NRES_ERROR_TAIL
virtual void suspend()=0
Set the status to Suspended.
void setMiscReg(int miscReg, RegVal val)
virtual BaseCPU * getCpuPtr()=0
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
STickCompareEvent * sTickCompare
bool scheduled() const
Determine if the current event is scheduled.
#define panic(...)
This implements a cprintf based panic() function.
@ MISCREG_QUEUE_RES_ERROR_TAIL
Generated on Tue Dec 21 2021 11:34:23 for gem5 by doxygen 1.8.17