Go to the documentation of this file.
39 #include "debug/CCRegs.hh"
40 #include "debug/FloatRegs.hh"
41 #include "debug/IntRegs.hh"
42 #include "debug/MiscRegs.hh"
43 #include "params/X86ISA.hh"
54 SegAttr csAttr, SegAttr ssAttr, RFLAGS rflags)
58 m5reg.mode = LongMode;
64 m5reg.mode = LegacyMode;
74 m5reg.cpl = csAttr.dpl;
75 m5reg.paging = cr0.pg;
91 }
else if (csAttr.defaultSize) {
102 }
else if (ssAttr.defaultSize) {
136 LocalApicBase lApicBase = 0;
137 lApicBase.base = 0xFEE00000 >> 12;
138 lApicBase.enable = 1;
147 "CPUID vendor string must be 12 characters\n");
288 if (toggled.pg && efer.lme) {
320 if (toggled.pae || toggled.pse || toggled.pge) {
330 panic_if(rflags.vm,
"Virtual 8086 mode is not supported.");
336 SegAttr newCSAttr =
val;
337 if (toggled.longMode) {
338 if (newCSAttr.longMode) {
384 if (!efer.lma || !csAttr.longMode)
424 if (dr7.l0 || dr7.g0) {
425 panic(
"Debug register breakpoints not implemented.\n");
431 if (dr7.l1 || dr7.g1) {
432 panic(
"Debug register breakpoints not implemented.\n");
438 if (dr7.l2 || dr7.g2) {
439 panic(
"Debug register breakpoints not implemented.\n");
445 if (dr7.l3 || dr7.g3) {
446 panic(
"Debug register breakpoints not implemented.\n");
451 dr7.rw0 = newDR7.rw0;
452 dr7.len0 = newDR7.len0;
453 dr7.rw1 = newDR7.rw1;
454 dr7.len1 = newDR7.len1;
455 dr7.rw2 = newDR7.rw2;
456 dr7.len2 = newDR7.len2;
457 dr7.rw3 = newDR7.rw3;
458 dr7.len3 = newDR7.len3;
virtual RegVal readMiscReg(RegIndex misc_reg)=0
void copyRegsFrom(ThreadContext *src) override
static void copyMiscRegs(ThreadContext *src, ThreadContext *dest)
@ CCRegClass
Condition-code register.
virtual BaseMMU * getMMUPtr()=0
virtual const PCStateBase & pcState() const =0
static RegIndex segEffBase(int index)
virtual ContextID contextId() const =0
virtual RegVal getRegFlat(const RegId ®) const
Flat register interfaces.
void setMiscReg(int miscReg, RegVal val)
static bool isValid(int index)
void serialize(CheckpointOut &cp) const override
Serialize an object.
@ FloatRegClass
Floating-point register.
void unserialize(CheckpointIn &cp) override
Unserialize an object.
ThreadContext is the external interface to all thread state for anything outside of the CPU.
RegVal readMiscRegNoEffect(int miscReg) const
void setThreadContext(ThreadContext *_tc) override
virtual InstDecoder * getDecoderPtr()=0
virtual void setThreadContext(ThreadContext *_tc)
constexpr T insertBits(T val, unsigned first, unsigned last, B bit_val)
Returns val with bits first to last set to the LSBs of bit_val.
#define SERIALIZE_ARRAY(member, size)
virtual RegVal readMiscRegNoEffect(RegIndex misc_reg) const =0
virtual void setRegFlat(const RegId ®, RegVal val)
RegVal readMiscReg(int miscReg)
std::string getVendorString() const
RegVal regVal[misc_reg::NumRegs]
@ IntRegClass
Integer register.
#define panic_if(cond,...)
Conditional panic macro that checks the supplied condition and only panics if the condition is true a...
#define UNSERIALIZE_ARRAY(member, size)
virtual void setMiscReg(RegIndex misc_reg, RegVal val)=0
void updateHandyM5Reg(Efer efer, CR0 cr0, SegAttr csAttr, SegAttr ssAttr, RFLAGS rflags)
std::ostream CheckpointOut
virtual BaseCPU * getCpuPtr()=0
void setMiscRegNoEffect(int miscReg, RegVal val)
#define fatal_if(cond,...)
Conditional fatal macro that checks the supplied condition and only causes a fatal error if the condi...
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
Register ID: describe an architectural register with its class and index.
#define panic(...)
This implements a cprintf based panic() function.
virtual void setMiscRegNoEffect(RegIndex misc_reg, RegVal val)=0
Generated on Thu Jun 16 2022 10:41:35 for gem5 by doxygen 1.8.17