Go to the documentation of this file.
38 #ifndef __ARCH_ARM_KVM_ARM_CPU_HH__
39 #define __ARCH_ARM_KVM_ARM_CPU_HH__
45 #include "params/ArmKvmCPU.hh"
78 const ArmISA::IntRegIndex
idx;
134 bool getRegList(
struct kvm_reg_list ®s)
const;
173 #endif // __ARCH_ARM_KVM_ARM_CPU_HH__
void updateTCStateVFP(uint64_t id, bool show_warnings)
Tick kvmRun(Tick ticks)
Request KVM to run the guest for a given number of ticks.
const char * name
Name in debug output.
static const std::set< uint64_t > invariant_regs
List of co-processor registers that KVM requires to be identical on both the host and the guest.
void dumpKvmStateVFP(uint64_t id)
void kvmArmVCpuInit(uint32_t target)
std::vector< uint64_t > RegIndexVector
ArmISA::MiscRegIndex decodeCoProcReg(uint64_t id) const
void updateTCStateCoProc(uint64_t id, bool show_warnings)
void updateKvmState()
Update the KVM state from the current thread context.
ARM implementation of a KVM-based hardware virtualized CPU.
const ArmISA::MiscRegIndex idx
gem5 index
bool irqAsserted
Cached state of the IRQ line.
void updateKvmStateMisc()
void dumpKvmStateCoProc(uint64_t id)
void updateKvmStateVFP(uint64_t id, bool show_warnings)
const Params & params() const
Base class for KVM based CPU models.
const ArmISA::IntRegIndex idx
gem5 index
const char * name
Name in debug output.
uint64_t Tick
Tick count type.
ArmKvmCPU(const ArmKvmCPUParams ¶ms)
void updateKvmStateCoProc(uint64_t id, bool show_warnings)
void startup()
startup() is the final initialization call before simulation.
void updateKvmStateCore()
bool fiqAsserted
Cached state of the FIQ line.
void updateThreadContext()
Update the current thread context with the KVM state.
static KvmCoreMiscRegInfo kvmCoreMiscRegs[]
bool isInvariantReg(uint64_t id)
Determine if a register is invariant.
static KvmIntRegInfo kvmIntRegs[]
RegIndexVector _regIndexList
Cached copy of the list of co-processor registers supported by KVM.
const RegIndexVector & getRegList() const
Get a list of registers supported by getOneReg() and setOneReg().
void init() override
init() is called after all C++ SimObjects have been created and all ports are connected.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
ArmISA::MiscRegIndex decodeVFPCtrlReg(uint64_t id) const
Generated on Wed Jul 28 2021 12:10:21 for gem5 by doxygen 1.8.17