Go to the documentation of this file.
   39 #ifndef __CPU_KVM_KVMVM_HH__ 
   40 #define __CPU_KVM_KVMVM_HH__ 
   47 struct kvm_cpuid_entry2;
 
  154 #if defined(__i386__) || defined(__x86_64__) 
  171     bool getSupportedCPUID(
struct kvm_cpuid2 &
cpuid) 
const;
 
  183     const CPUIDVector &getSupportedCPUID() 
const;
 
  190     bool getSupportedMSRs(
struct kvm_msr_list &msrs) 
const;
 
  200     const MSRIndexVector &getSupportedMSRs() 
const;
 
  204     mutable CPUIDVector supportedCPUIDCache;
 
  207     mutable MSRIndexVector supportedMSRCache;
 
  239     int ioctl(
int request, 
long p1) 
const;
 
  240     int ioctl(
int request, 
void *p1)
 const {
 
  241         return ioctl(request, (
long)p1);
 
  244         return ioctl(request, 0
L);
 
  431 #if defined(__aarch64__) 
  444     void kvmArmPreferredTarget(
struct kvm_vcpu_init &target) 
const;
 
  484                              void *host_addr, 
Addr guest_addr,
 
  519     int ioctl(
int request, 
long p1) 
const;
 
  520     int ioctl(
int request, 
void *p1)
 const {
 
  521         return ioctl(request, (
long)p1);
 
  524         return ioctl(request, 0
L);
 
  
int getAPIVersion() const
Get the version of the KVM API implemented by the kernel.
int vmFD
KVM VM file descriptor.
int createVCPU(long vcpuID)
Create a new vCPU within a VM.
bool capSetTSSAddress() const
Support for KvmVM::setTSSAddress()
void freeMemSlot(const MemSlot slot)
Free a previously allocated memory slot.
bool capUserNMI() const
Support for BaseKvmCPU::kvmNonMaskableInterrupt().
void setUserMemoryRegion(uint32_t slot, void *host_addr, Addr guest_addr, uint64_t len, uint32_t flags)
Setup a region of physical memory in the guest.
static Kvm * instance
Singleton instance.
int capCoalescedMMIO() const
Check if coalesced MMIO is supported and which page in the MMAP'ed structure it stores requests in.
void createIRQChip()
Create an in-kernel interrupt controller.
void setTSSAddress(Addr tss_address)
Setup a shared three-page memory region used by the internals of KVM.
int ioctl(int request, void *p1) const
int ioctl(int request) const
long allocVCPUID()
Allocate a new vCPU ID within the VM.
void disableMemSlot(const MemSlot slot)
Disable a memory slot.
bool capExtendedCPUID() const
Support for BaseKvmCPU::setCPUID2 and getSupportedCPUID().
int ioctl(int request, long p1) const
KVM VM ioctl interface.
void coalesceMMIO(Addr start, int size)
Request coalescing MMIO for a memory range.
bool capUserMemory() const
Support for KvmVM::setUserMemoryRegion()
KvmVM(const KvmVMParams ¶ms)
bool capXCRs() const
Support for getting and setting the x86 XCRs.
bool capXSave() const
Support for getting and setting the kvm_xsave structure.
bool capIRQChip() const
Support for creating an in-kernel IRQ chip model.
int checkExtension(int extension) const
Check for the presence of an extension to the KVM API.
bool capVCPUEvents() const
Support for getting and setting the kvm_vcpu_events structure.
const Params & params() const
Base class for KVM based CPU models.
int vcpuMMapSize
Size of the MMAPed vCPU parameter area.
bool _hasKernelIRQChip
Do we have in-kernel IRQ-chip emulation enabled?
int getVCPUMMapSize() const
Get the size of the MMAPed parameter area used to communicate vCPU parameters between the kernel and ...
int ioctl(int request, void *p1) const
int kvmFD
KVM VM file descriptor.
bool started
Has delayedStartup() already been called?
void setIRQLine(uint32_t irq, bool high)
Set the status of an IRQ line using KVM_IRQ_LINE.
void enableKernelIRQChip()
Tell the VM and VCPUs to use an in-kernel IRQ chip for interrupt delivery.
void delayedStartup()
Delayed initialization, executed once before the first CPU starts.
int ioctl(int request, long p1) const
Main VM ioctl interface.
Abstract superclass for simulation objects.
long contextIdToVCpuId(ContextID ctx) const
Get the VCPUID for a given context.
uint64_t Addr
Address type This will probably be moved somewhere else in the near future.
Kvm * kvm
Global KVM interface.
int ioctl(int request) const
KvmVM & operator=(const KvmVM &vm)
void cpuStartup()
VM CPU initialization code.
Structures tracking memory slots.
const MemSlot allocMemSlot(uint64_t size)
Allocate a memory slot within the VM.
bool capDebugRegs() const
Support for getting and setting the kvm_debugregs structure.
long nextVCPUID
Next unallocated vCPU ID.
int ContextID
Globally unique thread context ID.
bool validEnvironment() const
Verify gem5 configuration will support KVM emulation.
int capNumMemSlots() const
Attempt to determine how many memory slots are available.
The AddrRange class encapsulates an address range, and supports a number of tests to check if two ran...
int apiVersion
KVM API version.
Reference material can be found at the JEDEC website: UFS standard http://www.jedec....
void notifyFork()
Notify a child process of a fork.
std::vector< MemorySlot > memorySlots
bool capOneReg() const
Support for reading and writing single registers.
bool capIRQLineLayout2() const
Support for ARM IRQ line layout 2.
bool hasKernelIRQChip() const
Is in-kernel IRQ chip emulation enabled?
int createVM()
Create a KVM Virtual Machine.
void setupMemSlot(const MemSlot slot, void *host_addr, Addr guest_addr, uint32_t flags)
Setup a region of physical memory in the guest.
Kvm & operator=(const Kvm &kvm)
int createDevice(uint32_t type, uint32_t flags=0)
Create an in-kernel device model.
Generated on Thu Jul 28 2022 13:32:28 for gem5 by  doxygen 1.8.17