35 #include "params/X86ISA.hh" 43 SegAttr csAttr, SegAttr ssAttr, RFLAGS rflags,
48 m5reg.mode = LongMode;
54 m5reg.mode = LegacyMode;
64 m5reg.cpl = csAttr.dpl;
65 m5reg.paging = cr0.pg;
81 }
else if (csAttr.defaultSize) {
92 }
else if (ssAttr.defaultSize) {
126 LocalApicBase lApicBase = 0;
127 lApicBase.base = 0xFEE00000 >> 12;
128 lApicBase.enable = 1;
231 if (toggled.pg && efer.lme) {
266 if (toggled.pae || toggled.pse || toggled.pge) {
277 SegAttr newCSAttr =
val;
278 if (toggled.longMode) {
279 if (newCSAttr.longMode) {
327 if (!efer.lma || !csAttr.longMode)
367 if (dr7.l0 || dr7.g0) {
368 panic(
"Debug register breakpoints not implemented.\n");
374 if (dr7.l1 || dr7.g1) {
375 panic(
"Debug register breakpoints not implemented.\n");
381 if (dr7.l2 || dr7.g2) {
382 panic(
"Debug register breakpoints not implemented.\n");
388 if (dr7.l3 || dr7.g3) {
389 panic(
"Debug register breakpoints not implemented.\n");
394 dr7.rw0 = newDR7.rw0;
395 dr7.len0 = newDR7.len0;
396 dr7.rw1 = newDR7.rw1;
397 dr7.len1 = newDR7.len1;
398 dr7.rw2 = newDR7.rw2;
399 dr7.len2 = newDR7.len2;
400 dr7.rw3 = newDR7.rw3;
401 dr7.len3 = newDR7.len3;
448 X86ISAParams::create()
#define panic(...)
This implements a cprintf based panic() function.
RegVal readMiscReg(int miscReg, ThreadContext *tc)
void serialize(CheckpointOut &cp) const override
Serialize an object.
virtual TheISA::Decoder * getDecoderPtr()=0
virtual BaseTLB * getDTBPtr()=0
const Params * params() const
void updateHandyM5Reg(Efer efer, CR0 cr0, SegAttr csAttr, SegAttr ssAttr, RFLAGS rflags, ThreadContext *tc)
virtual BaseCPU * getCpuPtr()=0
static bool isValidMiscReg(int index)
ThreadContext is the external interface to all thread state for anything outside of the CPU...
void setMiscReg(int miscReg, RegVal val, ThreadContext *tc)
virtual void startup()
startup() is the final initialization call before simulation.
RegVal readMiscRegNoEffect(int miscReg) const
void unserialize(CheckpointIn &cp) override
Unserialize an object.
void setMiscRegNoEffect(int miscReg, RegVal val)
virtual BaseTLB * getITBPtr()=0
Cycles curCycle() const
Determine the current cycle, corresponding to a tick aligned to a clock edge.
T insertBits(T val, int first, int last, B bit_val)
Returns val with bits first to last set to the LSBs of bit_val.
#define ULL(N)
uint64_t constant
#define SERIALIZE_ARRAY(member, size)
RegVal regVal[NUM_MISCREGS]
#define UNSERIALIZE_ARRAY(member, size)
std::ostream CheckpointOut
This is exposed globally, independent of the ISA.
const SimObjectParams * _params
Cached copy of the object parameters.
virtual ContextID contextId() const =0
static MiscRegIndex MISCREG_SEG_EFF_BASE(int index)