38 #include "debug/MiscRegs.hh" 39 #include "debug/Timer.hh" 40 #include "params/SparcISA.hh" 71 const SparcISAParams *
108 mapChunk[
i] =
i + gl * NumGlobalRegs;
128 memset(
tpc, 0,
sizeof(
tpc));
131 memset(
tt, 0,
sizeof(
tt));
171 panic(
"Tick comparison event active when clearing the ISA object.\n");
196 return (uint64_t)
hpstate.hpriv |
198 (uint64_t)
pstate.priv << 2 |
199 (uint64_t)
pstate.am << 3 |
202 bits((uint64_t)
tl,2,0) << 16 |
221 panic(
"PCR not implemented\n");
223 panic(
"PIC not implemented\n");
245 panic(
"Priviliged access to tick registers not implemented\n");
331 panic(
"Miscellaneous register %d not implemented\n", miscReg);
347 DPRINTF(Timer,
"Instruction Count when TICK read: %#X stick=%#X\n",
356 panic(
"Performance Instrumentation not impl\n");
359 panic(
"Can read from softint clr/set\n");
403 panic(
"PCR not implemented\n");
405 panic(
"PIC not implemented\n");
436 panic(
"Priviliged access to tick regesiters not implemented\n");
495 DPRINTF(MiscRegs,
"FSR written with: %#x\n",
fsr);
560 panic(
"Miscellaneous register %d not implemented\n", miscReg);
579 DPRINTF(Timer,
"Writing TICK=%#X\n", val);
681 Tick tick_cmp = 0, stick_cmp = 0, hstick_cmp = 0;
685 bool tick_intr_sched =
true;
694 tick_intr_sched =
false;
767 Tick tick_cmp = 0, stick_cmp = 0, hstick_cmp = 0;
771 bool tick_intr_sched;
773 if (tick_intr_sched) {
802 SparcISAParams::create()
#define panic(...)
This implements a cprintf based panic() function.
RegVal readMiscRegNoEffect(int miscReg) const
int findContext(ThreadContext *tc)
Given a Thread Context pointer return the thread num.
virtual TheISA::Decoder * getDecoderPtr()=0
void installGlobals(int gl, int offset)
CpuEventWrapper< ISA, &ISA::processSTickCompare > STickCompareEvent
void serialize(CheckpointOut &cp) const override
Serialize an object.
static const int NumWindowedRegs
#define SERIALIZE_OBJPTR(objptr)
void clearInterrupt(ThreadID tid, int int_num, int index)
static const PSTATE PstateMask
TickCompareEvent * tickCompare
virtual BaseCPU * getCpuPtr()=0
CpuEventWrapper< ISA, &ISA::processTickCompare > TickCompareEvent
RegIndex intRegMap[TotalInstIntRegs]
ThreadContext is the external interface to all thread state for anything outside of the CPU...
uint64_t fsr
Floating point misc registers.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
#define UNSERIALIZE_SCALAR(scalar)
static const int NumGlobalRegs
uint64_t Tick
Tick count type.
Hyper privileged registers.
RegVal readMiscReg(int miscReg, ThreadContext *tc)
HPSTATE hpstate
Hyperprivileged Registers.
CpuEventWrapper< ISA, &ISA::processHSTickCompare > HSTickCompareEvent
static PSTATE buildPstateMask()
void schedule(Event &event, Tick when)
void setMiscReg(int miscReg, RegVal val, ThreadContext *tc)
static const int RegsPerWindow
#define ULL(N)
uint64_t constant
#define SERIALIZE_ARRAY(member, size)
HSTickCompareEvent * hSTickCompare
Ancillary State Registers.
RegVal readFSReg(int miscReg, ThreadContext *tc)
#define SERIALIZE_SCALAR(scalar)
bool scheduled() const
Determine if the current event is scheduled.
#define UNSERIALIZE_ARRAY(member, size)
std::ostream CheckpointOut
STickCompareEvent * sTickCompare
const SimObjectParams * _params
Cached copy of the object parameters.
virtual ThreadContext * getContext(int tn)
Given a thread num get tho thread context for it.
const Params * params() const
T mbits(T val, int first, int last)
Mask off the given bits in place like bits() but without shifting.
T bits(T val, int first, int last)
Extract the bitfield from position 'first' to 'last' (inclusive) from 'val' and right justify it...
static const int TotalGlobals
static const int TotalWindowed
Tick when() const
Get the time that the event is scheduled.
uint16_t priContext
MMU Internal Registers.
#define UNSERIALIZE_OBJPTR(objptr)
void postInterrupt(ThreadID tid, int int_num, int index)
void installWindow(int cwp, int offset)
void setMiscRegNoEffect(int miscReg, RegVal val)
void setFSReg(int miscReg, RegVal val, ThreadContext *tc)
Floating Point Status Register.