Changeset View
Changeset View
Standalone View
Standalone View
sys/amd64/vmm/vmm_dev.c
Show First 20 Lines • Show All 54 Lines • ▼ Show 20 Lines | |||||
#include <machine/vmparam.h> | #include <machine/vmparam.h> | ||||
#include <machine/vmm.h> | #include <machine/vmm.h> | ||||
#include <machine/vmm_dev.h> | #include <machine/vmm_dev.h> | ||||
#include <machine/vmm_instruction_emul.h> | #include <machine/vmm_instruction_emul.h> | ||||
#include <machine/vmm_snapshot.h> | #include <machine/vmm_snapshot.h> | ||||
#include <x86/apicreg.h> | #include <x86/apicreg.h> | ||||
#include "amd/amdgpu.h" | |||||
#include "vmm_lapic.h" | #include "vmm_lapic.h" | ||||
#include "vmm_stat.h" | #include "vmm_stat.h" | ||||
#include "vmm_mem.h" | #include "vmm_mem.h" | ||||
#include "io/ppt.h" | #include "io/ppt.h" | ||||
#include "io/vatpic.h" | #include "io/vatpic.h" | ||||
#include "io/vioapic.h" | #include "io/vioapic.h" | ||||
#include "io/vhpet.h" | #include "io/vhpet.h" | ||||
#include "io/vrtc.h" | #include "io/vrtc.h" | ||||
▲ Show 20 Lines • Show All 290 Lines • ▼ Show 20 Lines | vmmdev_ioctl(struct cdev *cdev, u_long cmd, caddr_t data, int fflag, | ||||
struct vm_lapic_irq *vmirq; | struct vm_lapic_irq *vmirq; | ||||
struct vm_lapic_msi *vmmsi; | struct vm_lapic_msi *vmmsi; | ||||
struct vm_ioapic_irq *ioapic_irq; | struct vm_ioapic_irq *ioapic_irq; | ||||
struct vm_isa_irq *isa_irq; | struct vm_isa_irq *isa_irq; | ||||
struct vm_isa_irq_trigger *isa_irq_trigger; | struct vm_isa_irq_trigger *isa_irq_trigger; | ||||
struct vm_capability *vmcap; | struct vm_capability *vmcap; | ||||
struct vm_pptdev *pptdev; | struct vm_pptdev *pptdev; | ||||
struct vm_pptdev_mmio *pptmmio; | struct vm_pptdev_mmio *pptmmio; | ||||
struct vm_vbios *vbios; | |||||
struct vm_pptdev_msi *pptmsi; | struct vm_pptdev_msi *pptmsi; | ||||
struct vm_pptdev_msix *pptmsix; | struct vm_pptdev_msix *pptmsix; | ||||
struct vm_nmi *vmnmi; | struct vm_nmi *vmnmi; | ||||
struct vm_stats *vmstats; | struct vm_stats *vmstats; | ||||
struct vm_stat_desc *statdesc; | struct vm_stat_desc *statdesc; | ||||
struct vm_x2apic *x2apic; | struct vm_x2apic *x2apic; | ||||
struct vm_gpa_pte *gpapte; | struct vm_gpa_pte *gpapte; | ||||
struct vm_suspend *vmsuspend; | struct vm_suspend *vmsuspend; | ||||
▲ Show 20 Lines • Show All 53 Lines • ▼ Show 20 Lines | case VM_RESTART_INSTRUCTION: | ||||
vcpu = *(int *)data; | vcpu = *(int *)data; | ||||
error = vcpu_lock_one(sc, vcpu); | error = vcpu_lock_one(sc, vcpu); | ||||
if (error) | if (error) | ||||
goto done; | goto done; | ||||
state_changed = 1; | state_changed = 1; | ||||
break; | break; | ||||
case VM_MAP_PPTDEV_MMIO: | case VM_MAP_PPTDEV_MMIO: | ||||
case VM_GET_VBIOS: | |||||
case VM_BIND_PPTDEV: | case VM_BIND_PPTDEV: | ||||
case VM_UNBIND_PPTDEV: | case VM_UNBIND_PPTDEV: | ||||
#ifdef COMPAT_FREEBSD12 | #ifdef COMPAT_FREEBSD12 | ||||
case VM_ALLOC_MEMSEG_FBSD12: | case VM_ALLOC_MEMSEG_FBSD12: | ||||
#endif | #endif | ||||
case VM_ALLOC_MEMSEG: | case VM_ALLOC_MEMSEG: | ||||
case VM_MMAP_MEMSEG: | case VM_MMAP_MEMSEG: | ||||
case VM_REINIT: | case VM_REINIT: | ||||
▲ Show 20 Lines • Show All 68 Lines • ▼ Show 20 Lines | error = ppt_setup_msix(sc->vm, pptmsix->vcpu, | ||||
pptmsix->addr, pptmsix->msg, | pptmsix->addr, pptmsix->msg, | ||||
pptmsix->vector_control); | pptmsix->vector_control); | ||||
break; | break; | ||||
case VM_MAP_PPTDEV_MMIO: | case VM_MAP_PPTDEV_MMIO: | ||||
pptmmio = (struct vm_pptdev_mmio *)data; | pptmmio = (struct vm_pptdev_mmio *)data; | ||||
error = ppt_map_mmio(sc->vm, pptmmio->bus, pptmmio->slot, | error = ppt_map_mmio(sc->vm, pptmmio->bus, pptmmio->slot, | ||||
pptmmio->func, pptmmio->gpa, pptmmio->len, | pptmmio->func, pptmmio->gpa, pptmmio->len, | ||||
pptmmio->hpa); | pptmmio->hpa); | ||||
break; | |||||
case VM_GET_VBIOS: | |||||
vbios = (struct vm_vbios *)data; | |||||
// currently only amd cpus are supported | |||||
error = vm_amdgpu_get_vbios(sc->vm, vbios->bus, vbios->slot, vbios->func, | |||||
vbios->vendor, vbios->dev_id, vbios->bios, &vbios->size); | |||||
break; | break; | ||||
case VM_BIND_PPTDEV: | case VM_BIND_PPTDEV: | ||||
pptdev = (struct vm_pptdev *)data; | pptdev = (struct vm_pptdev *)data; | ||||
error = vm_assign_pptdev(sc->vm, pptdev->bus, pptdev->slot, | error = vm_assign_pptdev(sc->vm, pptdev->bus, pptdev->slot, | ||||
pptdev->func); | pptdev->func); | ||||
break; | break; | ||||
case VM_UNBIND_PPTDEV: | case VM_UNBIND_PPTDEV: | ||||
pptdev = (struct vm_pptdev *)data; | pptdev = (struct vm_pptdev *)data; | ||||
▲ Show 20 Lines • Show All 709 Lines • Show Last 20 Lines |