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 Wed May 4 2022 12:13:50 for gem5 by  doxygen 1.8.17