Go to the documentation of this file.
29 #ifndef __CPU_KVM_X86_CPU_HH__
30 #define __CPU_KVM_X86_CPU_HH__
37 #include "params/X86KvmCPU.hh"
42 struct kvm_vcpu_events;
61 void dump()
const override;
116 void setMSRs(
const struct kvm_msrs &msrs);
118 void getMSRs(
struct kvm_msrs &msrs)
const;
140 void getXCRs(
struct kvm_xcrs ®s)
const;
141 void setXCRs(
const struct kvm_xcrs ®s);
142 void getXSave(
struct kvm_xsave &xsave)
const;
143 void setXSave(
const struct kvm_xsave &xsave);
229 const struct kvm_sregs &sregs);
void dumpDebugRegs() const
void setCPUID(const struct kvm_cpuid2 &cpuid)
Methods to access CPUID information using the extended API.
void updateThreadContextRegs(const struct kvm_regs ®s, const struct kvm_sregs &sregs)
Support routines to update the state of gem5's thread context from KVM's state representation.
void dumpSpecRegs() const
void dumpVCpuEvents() const
bool haveXSave
Kvm::capXSave() available?
void handleIOMiscReg32(int miscreg)
Handle a 32-bit IO access that should be mapped to a MiscReg.
void getDebugRegisters(struct kvm_debugregs ®s) const
Wrappers around KVM's state transfer methods.
void updateKvmStateFPU()
Update FPU and SIMD registers.
void updateKvmStateRegs()
Support routines to update the state of the KVM CPU from gem5's state representation.
void setMSRs(const struct kvm_msrs &msrs)
Methods to access MSRs in the guest.
void setDebugRegisters(const struct kvm_debugregs ®s)
void updateThreadContextXSave(const struct kvm_xsave &kxsave)
Update FPU and SIMD registers using the XSave API.
void updateCPUID()
Transfer gem5's CPUID values into the virtual CPU.
void updateThreadContextFPU(const struct kvm_fpu &fpu)
Update FPU and SIMD registers using the legacy API.
Kvm::MSRIndexVector cachedMsrIntersection
Cached intersection of supported MSRs.
void setMSR(uint32_t index, uint64_t value)
Tick kvmRunDrain() override
Run the virtual CPU until draining completes.
void ioctlRun() override
Override for synchronizing state in kvm_run.
bool archIsDrained() const override
Check if there are pending events in the vCPU that prevents it from being drained.
const Kvm::MSRIndexVector & getMsrIntersection() const
Get a list of MSRs supported by both gem5 and KVM.
std::vector< struct kvm_msr_entry > KvmMSRVector
bool haveDebugRegs
Kvm::capDebugRegs() available?
uint64_t getMSR(uint32_t index) const
void updateKvmStateSRegs()
Update control registers (CRx, segments, etc.)
Base class for KVM based CPU models.
uint64_t Tick
Tick count type.
void updateKvmStateMSRs()
Update MSR registers.
void setXCRs(const struct kvm_xcrs ®s)
void getMSRs(struct kvm_msrs &msrs) const
x86 implementation of a KVM-based hardware virtualized CPU.
uint64_t getHostCycles() const override
Get the value of the hardware cycle counter in the guest.
Tick handleKvmExitIO() override
Handle x86 legacy IO (in/out)
void updateThreadContextMSRs()
Update MSR registers.
void updateKvmState() override
Update the KVM state from the current thread context.
void getVCpuEvents(struct kvm_vcpu_events &events) const
void getXSave(struct kvm_xsave &xsave) const
void deliverInterrupts()
Inject pending interrupts from gem5 into the virtual CPU.
void dump() const override
Dump the internal state to the terminal.
bool haveXCRs
Kvm::capXCRs() available?
void updateKvmStateFPUXSave()
Update FPU and SIMD registers using the XSave API.
void stutterPC(PCStateBase &pc) const override
Modify a PCStatePtr's value so that its next PC is the current PC.
void updateKvmStateFPULegacy()
Update FPU and SIMD registers using the legacy API.
X86KvmCPU(const X86KvmCPUParams ¶ms)
Tick kvmRun(Tick ticks) override
Request KVM to run the guest for a given number of ticks.
Tick handleKvmExitIRQWindowOpen() override
The guest exited because an interrupt window was requested.
void setXSave(const struct kvm_xsave &xsave)
void getXCRs(struct kvm_xcrs ®s) const
void updateThreadContextSRegs(const struct kvm_sregs &sregs)
Update control registers (CRx, segments, etc.)
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
void updateThreadContext() override
Update the current thread context with the KVM state.
bool useXSave
Should the XSave interface be used to sync the FPU and SIMD registers?
void setVCpuEvents(const struct kvm_vcpu_events &events)
Generated on Wed May 4 2022 12:13:50 for gem5 by doxygen 1.8.17