summary refs log tree commit diff
path: root/kvm_sys
diff options
context:
space:
mode:
authorStephen Barber <smbarber@chromium.org>2017-07-10 18:33:19 -0700
committerchrome-bot <chrome-bot@chromium.org>2017-07-13 22:03:30 -0700
commitc4968f7de9841c0013170534888fe4484d1a2d73 (patch)
tree022fd86e74d5b3d033d997f9b4708282796f9913 /kvm_sys
parent8686d9ff5b11d3b72be1d05cff4bc62e41a02db7 (diff)
downloadcrosvm-c4968f7de9841c0013170534888fe4484d1a2d73.tar
crosvm-c4968f7de9841c0013170534888fe4484d1a2d73.tar.gz
crosvm-c4968f7de9841c0013170534888fe4484d1a2d73.tar.bz2
crosvm-c4968f7de9841c0013170534888fe4484d1a2d73.tar.lz
crosvm-c4968f7de9841c0013170534888fe4484d1a2d73.tar.xz
crosvm-c4968f7de9841c0013170534888fe4484d1a2d73.tar.zst
crosvm-c4968f7de9841c0013170534888fe4484d1a2d73.zip
sys_util: add ioctl module
Factor out common ioctl wrappers and macros into their own module.

Signed-off-by: Stephen Barber <smbarber@chromium.org>

BUG=none
TEST=cargo test

Change-Id: Ibede8a853f5cc6c6d62565930f312b11024cc5b5
Reviewed-on: https://chromium-review.googlesource.com/566540
Commit-Ready: Stephen Barber <smbarber@chromium.org>
Tested-by: Stephen Barber <smbarber@chromium.org>
Reviewed-by: Stephen Barber <smbarber@chromium.org>
Reviewed-by: Zach Reizner <zachr@chromium.org>
Diffstat (limited to 'kvm_sys')
-rw-r--r--kvm_sys/Cargo.toml3
-rw-r--r--kvm_sys/src/lib.rs224
2 files changed, 98 insertions, 129 deletions
diff --git a/kvm_sys/Cargo.toml b/kvm_sys/Cargo.toml
index 93d3fc0..c6f2e96 100644
--- a/kvm_sys/Cargo.toml
+++ b/kvm_sys/Cargo.toml
@@ -5,3 +5,6 @@ authors = ["The Chromium OS Authors"]
 
 [dev-dependencies]
 libc = "0.2.21"
+
+[dependencies]
+sys_util = { path = "../sys_util" }
diff --git a/kvm_sys/src/lib.rs b/kvm_sys/src/lib.rs
index b71d46d..58269c7 100644
--- a/kvm_sys/src/lib.rs
+++ b/kvm_sys/src/lib.rs
@@ -6,46 +6,12 @@
 #![allow(non_camel_case_types)]
 #![allow(non_snake_case)]
 
+#[macro_use]
+extern crate sys_util;
+
 // Somehow this one gets missed by bindgen
 pub const KVM_EXIT_IO_OUT: ::std::os::raw::c_uint = 1;
 
-// Each ioctl number gets a function instead of a constant because size_of can
-// not be used in const expressions.
-macro_rules! ioctl_ioc_nr {
-    ($name:ident, $dir:expr, $ty:expr, $nr:expr, $size:expr) => (
-        pub fn $name() -> ::std::os::raw::c_ulong {
-            (($dir << _IOC_DIRSHIFT) |
-            ($ty << _IOC_TYPESHIFT) |
-            ($nr<< _IOC_NRSHIFT) |
-            ($size << _IOC_SIZESHIFT)) as ::std::os::raw::c_ulong
-        }
-    )
-}
-
-macro_rules! ioctl_io_nr {
-    ($name:ident, $nr:expr) => (
-        ioctl_ioc_nr!($name, _IOC_NONE, KVMIO, $nr, 0);
-    )
-}
-
-macro_rules! ioctl_ior_nr {
-    ($name:ident, $nr:expr, $size:ty) => (
-        ioctl_ioc_nr!($name, _IOC_READ, KVMIO, $nr, ::std::mem::size_of::<$size>() as u32);
-    )
-}
-
-macro_rules! ioctl_iow_nr {
-    ($name:ident, $nr:expr, $size:ty) => (
-        ioctl_ioc_nr!($name, _IOC_WRITE, KVMIO, $nr, ::std::mem::size_of::<$size>() as u32);
-    )
-}
-
-macro_rules! ioctl_iowr_nr {
-    ($name:ident, $nr:expr, $size:ty) => (
-        ioctl_ioc_nr!($name, _IOC_READ|_IOC_WRITE, KVMIO, $nr, ::std::mem::size_of::<$size>() as u32);
-    )
-}
-
 // Each of the below modules defines ioctls specific to their platform.
 
 #[cfg(any(target_arch = "x86", target_arch = "x86_64"))]
@@ -54,31 +20,31 @@ pub mod x86 {
     pub mod bindings;
     pub use bindings::*;
 
-    ioctl_iowr_nr!(KVM_GET_MSR_INDEX_LIST, 0x02, kvm_msr_list);
-    ioctl_iowr_nr!(KVM_GET_SUPPORTED_CPUID, 0x05, kvm_cpuid2);
-    ioctl_iowr_nr!(KVM_GET_EMULATED_CPUID, 0x09, kvm_cpuid2);
-    ioctl_iow_nr!(KVM_SET_MEMORY_ALIAS, 0x43, kvm_memory_alias);
-    ioctl_iow_nr!(KVM_XEN_HVM_CONFIG, 0x7a, kvm_xen_hvm_config);
-    ioctl_ior_nr!(KVM_GET_PIT2, 0x9f, kvm_pit_state2);
-    ioctl_iow_nr!(KVM_SET_PIT2, 0xa0, kvm_pit_state2);
-    ioctl_iowr_nr!(KVM_GET_MSRS, 0x88, kvm_msrs);
-    ioctl_iow_nr!(KVM_SET_MSRS, 0x89, kvm_msrs);
-    ioctl_iow_nr!(KVM_SET_CPUID, 0x8a, kvm_cpuid);
-    ioctl_ior_nr!(KVM_GET_LAPIC, 0x8e, kvm_lapic_state);
-    ioctl_iow_nr!(KVM_SET_LAPIC, 0x8f, kvm_lapic_state);
-    ioctl_iow_nr!(KVM_SET_CPUID2, 0x90, kvm_cpuid2);
-    ioctl_iowr_nr!(KVM_GET_CPUID2, 0x91, kvm_cpuid2);
-    ioctl_iow_nr!(KVM_X86_SETUP_MCE, 0x9c, __u64);
-    ioctl_ior_nr!(KVM_X86_GET_MCE_CAP_SUPPORTED, 0x9d, __u64);
-    ioctl_iow_nr!(KVM_X86_SET_MCE, 0x9e, kvm_x86_mce);
-    ioctl_ior_nr!(KVM_GET_VCPU_EVENTS, 0x9f, kvm_vcpu_events);
-    ioctl_iow_nr!(KVM_SET_VCPU_EVENTS, 0xa0, kvm_vcpu_events);
-    ioctl_ior_nr!(KVM_GET_DEBUGREGS, 0xa1, kvm_debugregs);
-    ioctl_iow_nr!(KVM_SET_DEBUGREGS, 0xa2, kvm_debugregs);
-    ioctl_ior_nr!(KVM_GET_XSAVE, 0xa4, kvm_xsave);
-    ioctl_iow_nr!(KVM_SET_XSAVE, 0xa5, kvm_xsave);
-    ioctl_ior_nr!(KVM_GET_XCRS, 0xa6, kvm_xcrs);
-    ioctl_iowr_nr!(KVM_SET_XCRS, 0xa7, kvm_xcrs);
+    ioctl_iowr_nr!(KVM_GET_MSR_INDEX_LIST, KVMIO, 0x02, kvm_msr_list);
+    ioctl_iowr_nr!(KVM_GET_SUPPORTED_CPUID, KVMIO, 0x05, kvm_cpuid2);
+    ioctl_iowr_nr!(KVM_GET_EMULATED_CPUID, KVMIO, 0x09, kvm_cpuid2);
+    ioctl_iow_nr!(KVM_SET_MEMORY_ALIAS, KVMIO, 0x43, kvm_memory_alias);
+    ioctl_iow_nr!(KVM_XEN_HVM_CONFIG, KVMIO, 0x7a, kvm_xen_hvm_config);
+    ioctl_ior_nr!(KVM_GET_PIT2, KVMIO, 0x9f, kvm_pit_state2);
+    ioctl_iow_nr!(KVM_SET_PIT2, KVMIO, 0xa0, kvm_pit_state2);
+    ioctl_iowr_nr!(KVM_GET_MSRS, KVMIO, 0x88, kvm_msrs);
+    ioctl_iow_nr!(KVM_SET_MSRS, KVMIO, 0x89, kvm_msrs);
+    ioctl_iow_nr!(KVM_SET_CPUID, KVMIO, 0x8a, kvm_cpuid);
+    ioctl_ior_nr!(KVM_GET_LAPIC, KVMIO, 0x8e, kvm_lapic_state);
+    ioctl_iow_nr!(KVM_SET_LAPIC, KVMIO, 0x8f, kvm_lapic_state);
+    ioctl_iow_nr!(KVM_SET_CPUID2, KVMIO, 0x90, kvm_cpuid2);
+    ioctl_iowr_nr!(KVM_GET_CPUID2, KVMIO, 0x91, kvm_cpuid2);
+    ioctl_iow_nr!(KVM_X86_SETUP_MCE, KVMIO, 0x9c, __u64);
+    ioctl_ior_nr!(KVM_X86_GET_MCE_CAP_SUPPORTED, KVMIO, 0x9d, __u64);
+    ioctl_iow_nr!(KVM_X86_SET_MCE, KVMIO, 0x9e, kvm_x86_mce);
+    ioctl_ior_nr!(KVM_GET_VCPU_EVENTS, KVMIO, 0x9f, kvm_vcpu_events);
+    ioctl_iow_nr!(KVM_SET_VCPU_EVENTS, KVMIO, 0xa0, kvm_vcpu_events);
+    ioctl_ior_nr!(KVM_GET_DEBUGREGS, KVMIO, 0xa1, kvm_debugregs);
+    ioctl_iow_nr!(KVM_SET_DEBUGREGS, KVMIO, 0xa2, kvm_debugregs);
+    ioctl_ior_nr!(KVM_GET_XSAVE, KVMIO, 0xa4, kvm_xsave);
+    ioctl_iow_nr!(KVM_SET_XSAVE, KVMIO, 0xa5, kvm_xsave);
+    ioctl_ior_nr!(KVM_GET_XCRS, KVMIO, 0xa6, kvm_xcrs);
+    ioctl_iowr_nr!(KVM_SET_XCRS, KVMIO, 0xa7, kvm_xcrs);
 }
 
 #[cfg(any(target_arch = "arm", target_arch = "aarch64"))]
@@ -87,80 +53,80 @@ pub mod arm {
     pub mod bindings;
     pub use bindings::*;
 
-    ioctl_iow_nr!(KVM_ARM_SET_DEVICE_ADDR, 0xab, kvm_arm_device_addr);
-    ioctl_iow_nr!(KVM_ARM_VCPU_INIT, 0xae, kvm_vcpu_init);
-    ioctl_ior_nr!(KVM_ARM_PREFERRED_TARGET, 0xaf, kvm_vcpu_init);
+    ioctl_iow_nr!(KVM_ARM_SET_DEVICE_ADDR, KVMIO, 0xab, kvm_arm_device_addr);
+    ioctl_iow_nr!(KVM_ARM_VCPU_INIT, KVMIO, 0xae, kvm_vcpu_init);
+    ioctl_ior_nr!(KVM_ARM_PREFERRED_TARGET, KVMIO, 0xaf, kvm_vcpu_init);
 }
 
 // These ioctls are commonly defined on all/multiple platforms.
-ioctl_io_nr!(KVM_GET_API_VERSION, 0x00);
-ioctl_io_nr!(KVM_CREATE_VM, 0x01);
-ioctl_io_nr!(KVM_CHECK_EXTENSION, 0x03);
-ioctl_io_nr!(KVM_GET_VCPU_MMAP_SIZE, 0x04) /* in bytes */;
-ioctl_iow_nr!(KVM_SET_MEMORY_REGION, 0x40, kvm_memory_region);
-ioctl_io_nr!(KVM_CREATE_VCPU, 0x41);
-ioctl_iow_nr!(KVM_GET_DIRTY_LOG, 0x42, kvm_dirty_log);
-ioctl_io_nr!(KVM_SET_NR_MMU_PAGES, 0x44);
-ioctl_io_nr!(KVM_GET_NR_MMU_PAGES, 0x45);
-ioctl_iow_nr!(KVM_SET_USER_MEMORY_REGION,0x46, kvm_userspace_memory_region);
-ioctl_io_nr!(KVM_SET_TSS_ADDR, 0x47);
-ioctl_iow_nr!(KVM_SET_IDENTITY_MAP_ADDR, 0x48, __u64);
-ioctl_io_nr!(KVM_CREATE_IRQCHIP, 0x60);
-ioctl_iow_nr!(KVM_IRQ_LINE, 0x61, kvm_irq_level);
-ioctl_iowr_nr!(KVM_GET_IRQCHIP, 0x62, kvm_irqchip);
-ioctl_ior_nr!(KVM_SET_IRQCHIP, 0x63, kvm_irqchip);
-ioctl_io_nr!(KVM_CREATE_PIT, 0x64);
-ioctl_iowr_nr!(KVM_IRQ_LINE_STATUS, 0x67, kvm_irq_level);
-ioctl_iow_nr!(KVM_REGISTER_COALESCED_MMIO, 0x67, kvm_coalesced_mmio_zone);
-ioctl_iow_nr!(KVM_UNREGISTER_COALESCED_MMIO, 0x68, kvm_coalesced_mmio_zone);
-ioctl_ior_nr!(KVM_ASSIGN_PCI_DEVICE, 0x69,  kvm_assigned_pci_dev);
-ioctl_iow_nr!(KVM_ASSIGN_DEV_IRQ, 0x70, kvm_assigned_irq);
-ioctl_io_nr!(KVM_REINJECT_CONTROL, 0x71);
-ioctl_iow_nr!(KVM_DEASSIGN_PCI_DEVICE, 0x72,  kvm_assigned_pci_dev);
-ioctl_iow_nr!(KVM_ASSIGN_SET_MSIX_NR, 0x73,  kvm_assigned_msix_nr);
-ioctl_iow_nr!(KVM_ASSIGN_SET_MSIX_ENTRY, 0x74,  kvm_assigned_msix_entry);
-ioctl_iow_nr!(KVM_DEASSIGN_DEV_IRQ, 0x75, kvm_assigned_irq);
-ioctl_iow_nr!(KVM_IRQFD, 0x76, kvm_irqfd);
-ioctl_iow_nr!(KVM_CREATE_PIT2, 0x77, kvm_pit_config);
-ioctl_io_nr!(KVM_SET_BOOT_CPU_ID, 0x78);
-ioctl_iow_nr!(KVM_IOEVENTFD, 0x79, kvm_ioeventfd);
-ioctl_iow_nr!(KVM_SET_CLOCK, 0x7b, kvm_clock_data);
-ioctl_ior_nr!(KVM_GET_CLOCK, 0x7c, kvm_clock_data);
-ioctl_io_nr!(KVM_SET_TSC_KHZ, 0xa2);
-ioctl_io_nr!(KVM_GET_TSC_KHZ, 0xa3);
-ioctl_iow_nr!(KVM_ASSIGN_SET_INTX_MASK, 0xa4,  kvm_assigned_pci_dev);
-ioctl_iow_nr!(KVM_SIGNAL_MSI, 0xa5, kvm_msi);
-ioctl_iowr_nr!(KVM_CREATE_DEVICE, 0xe0, kvm_create_device);
-ioctl_iow_nr!(KVM_SET_DEVICE_ATTR, 0xe1, kvm_device_attr);
-ioctl_iow_nr!(KVM_GET_DEVICE_ATTR, 0xe2, kvm_device_attr);
-ioctl_iow_nr!(KVM_HAS_DEVICE_ATTR, 0xe3, kvm_device_attr);
-ioctl_io_nr!(KVM_RUN, 0x80);
+ioctl_io_nr!(KVM_GET_API_VERSION, KVMIO, 0x00);
+ioctl_io_nr!(KVM_CREATE_VM, KVMIO, 0x01);
+ioctl_io_nr!(KVM_CHECK_EXTENSION, KVMIO, 0x03);
+ioctl_io_nr!(KVM_GET_VCPU_MMAP_SIZE, KVMIO, 0x04) /* in bytes */;
+ioctl_iow_nr!(KVM_SET_MEMORY_REGION, KVMIO, 0x40, kvm_memory_region);
+ioctl_io_nr!(KVM_CREATE_VCPU, KVMIO, 0x41);
+ioctl_iow_nr!(KVM_GET_DIRTY_LOG, KVMIO, 0x42, kvm_dirty_log);
+ioctl_io_nr!(KVM_SET_NR_MMU_PAGES, KVMIO, 0x44);
+ioctl_io_nr!(KVM_GET_NR_MMU_PAGES, KVMIO, 0x45);
+ioctl_iow_nr!(KVM_SET_USER_MEMORY_REGION,KVMIO, 0x46, kvm_userspace_memory_region);
+ioctl_io_nr!(KVM_SET_TSS_ADDR, KVMIO, 0x47);
+ioctl_iow_nr!(KVM_SET_IDENTITY_MAP_ADDR, KVMIO, 0x48, __u64);
+ioctl_io_nr!(KVM_CREATE_IRQCHIP, KVMIO, 0x60);
+ioctl_iow_nr!(KVM_IRQ_LINE, KVMIO, 0x61, kvm_irq_level);
+ioctl_iowr_nr!(KVM_GET_IRQCHIP, KVMIO, 0x62, kvm_irqchip);
+ioctl_ior_nr!(KVM_SET_IRQCHIP, KVMIO, 0x63, kvm_irqchip);
+ioctl_io_nr!(KVM_CREATE_PIT, KVMIO, 0x64);
+ioctl_iowr_nr!(KVM_IRQ_LINE_STATUS, KVMIO, 0x67, kvm_irq_level);
+ioctl_iow_nr!(KVM_REGISTER_COALESCED_MMIO, KVMIO, 0x67, kvm_coalesced_mmio_zone);
+ioctl_iow_nr!(KVM_UNREGISTER_COALESCED_MMIO, KVMIO, 0x68, kvm_coalesced_mmio_zone);
+ioctl_ior_nr!(KVM_ASSIGN_PCI_DEVICE, KVMIO, 0x69,  kvm_assigned_pci_dev);
+ioctl_iow_nr!(KVM_ASSIGN_DEV_IRQ, KVMIO, 0x70, kvm_assigned_irq);
+ioctl_io_nr!(KVM_REINJECT_CONTROL, KVMIO, 0x71);
+ioctl_iow_nr!(KVM_DEASSIGN_PCI_DEVICE, KVMIO, 0x72,  kvm_assigned_pci_dev);
+ioctl_iow_nr!(KVM_ASSIGN_SET_MSIX_NR, KVMIO, 0x73,  kvm_assigned_msix_nr);
+ioctl_iow_nr!(KVM_ASSIGN_SET_MSIX_ENTRY, KVMIO, 0x74,  kvm_assigned_msix_entry);
+ioctl_iow_nr!(KVM_DEASSIGN_DEV_IRQ, KVMIO, 0x75, kvm_assigned_irq);
+ioctl_iow_nr!(KVM_IRQFD, KVMIO, 0x76, kvm_irqfd);
+ioctl_iow_nr!(KVM_CREATE_PIT2, KVMIO, 0x77, kvm_pit_config);
+ioctl_io_nr!(KVM_SET_BOOT_CPU_ID, KVMIO, 0x78);
+ioctl_iow_nr!(KVM_IOEVENTFD, KVMIO, 0x79, kvm_ioeventfd);
+ioctl_iow_nr!(KVM_SET_CLOCK, KVMIO, 0x7b, kvm_clock_data);
+ioctl_ior_nr!(KVM_GET_CLOCK, KVMIO, 0x7c, kvm_clock_data);
+ioctl_io_nr!(KVM_SET_TSC_KHZ, KVMIO, 0xa2);
+ioctl_io_nr!(KVM_GET_TSC_KHZ, KVMIO, 0xa3);
+ioctl_iow_nr!(KVM_ASSIGN_SET_INTX_MASK, KVMIO, 0xa4,  kvm_assigned_pci_dev);
+ioctl_iow_nr!(KVM_SIGNAL_MSI, KVMIO, 0xa5, kvm_msi);
+ioctl_iowr_nr!(KVM_CREATE_DEVICE, KVMIO, 0xe0, kvm_create_device);
+ioctl_iow_nr!(KVM_SET_DEVICE_ATTR, KVMIO, 0xe1, kvm_device_attr);
+ioctl_iow_nr!(KVM_GET_DEVICE_ATTR, KVMIO, 0xe2, kvm_device_attr);
+ioctl_iow_nr!(KVM_HAS_DEVICE_ATTR, KVMIO, 0xe3, kvm_device_attr);
+ioctl_io_nr!(KVM_RUN, KVMIO, 0x80);
 // The following two ioctls are commonly defined but specifically excluded
 // from arm platforms.
 #[cfg(not(any(target_arch = "arm", target_arch = "aarch64")))]
-ioctl_ior_nr!(KVM_GET_REGS, 0x81, kvm_regs);
+ioctl_ior_nr!(KVM_GET_REGS, KVMIO, 0x81, kvm_regs);
 #[cfg(not(any(target_arch = "arm", target_arch = "aarch64")))]
-ioctl_iow_nr!(KVM_SET_REGS, 0x82, kvm_regs);
-ioctl_ior_nr!(KVM_GET_SREGS, 0x83, kvm_sregs);
-ioctl_iow_nr!(KVM_SET_SREGS, 0x84, kvm_sregs);
-ioctl_iowr_nr!(KVM_TRANSLATE, 0x85, kvm_translation);
-ioctl_iow_nr!(KVM_INTERRUPT, 0x86, kvm_interrupt);
-ioctl_iow_nr!(KVM_SET_SIGNAL_MASK, 0x8b, kvm_signal_mask);
-ioctl_ior_nr!(KVM_GET_FPU, 0x8c, kvm_fpu);
-ioctl_iow_nr!(KVM_SET_FPU, 0x8d, kvm_fpu);
-ioctl_iowr_nr!(KVM_TPR_ACCESS_REPORTING, 0x92, kvm_tpr_access_ctl);
-ioctl_iow_nr!(KVM_SET_VAPIC_ADDR, 0x93, kvm_vapic_addr);
-ioctl_ior_nr!(KVM_GET_MP_STATE, 0x98, kvm_mp_state);
-ioctl_iow_nr!(KVM_SET_MP_STATE, 0x99, kvm_mp_state);
-ioctl_io_nr!(KVM_NMI, 0x9a);
-ioctl_iow_nr!(KVM_SET_GUEST_DEBUG, 0x9b, kvm_guest_debug);
-ioctl_iow_nr!(KVM_ENABLE_CAP, 0xa3, kvm_enable_cap);
-ioctl_iow_nr!(KVM_DIRTY_TLB, 0xaa, kvm_dirty_tlb);
-ioctl_iow_nr!(KVM_GET_ONE_REG, 0xab, kvm_one_reg);
-ioctl_iow_nr!(KVM_SET_ONE_REG, 0xac, kvm_one_reg);
-ioctl_io_nr!(KVM_KVMCLOCK_CTRL, 0xad);
-ioctl_iowr_nr!(KVM_GET_REG_LIST, 0xb0, kvm_reg_list);
-ioctl_io_nr!(KVM_SMI, 0xb7);
+ioctl_iow_nr!(KVM_SET_REGS, KVMIO, 0x82, kvm_regs);
+ioctl_ior_nr!(KVM_GET_SREGS, KVMIO, 0x83, kvm_sregs);
+ioctl_iow_nr!(KVM_SET_SREGS, KVMIO, 0x84, kvm_sregs);
+ioctl_iowr_nr!(KVM_TRANSLATE, KVMIO, 0x85, kvm_translation);
+ioctl_iow_nr!(KVM_INTERRUPT, KVMIO, 0x86, kvm_interrupt);
+ioctl_iow_nr!(KVM_SET_SIGNAL_MASK, KVMIO, 0x8b, kvm_signal_mask);
+ioctl_ior_nr!(KVM_GET_FPU, KVMIO, 0x8c, kvm_fpu);
+ioctl_iow_nr!(KVM_SET_FPU, KVMIO, 0x8d, kvm_fpu);
+ioctl_iowr_nr!(KVM_TPR_ACCESS_REPORTING, KVMIO, 0x92, kvm_tpr_access_ctl);
+ioctl_iow_nr!(KVM_SET_VAPIC_ADDR, KVMIO, 0x93, kvm_vapic_addr);
+ioctl_ior_nr!(KVM_GET_MP_STATE, KVMIO, 0x98, kvm_mp_state);
+ioctl_iow_nr!(KVM_SET_MP_STATE, KVMIO, 0x99, kvm_mp_state);
+ioctl_io_nr!(KVM_NMI, KVMIO, 0x9a);
+ioctl_iow_nr!(KVM_SET_GUEST_DEBUG, KVMIO, 0x9b, kvm_guest_debug);
+ioctl_iow_nr!(KVM_ENABLE_CAP, KVMIO, 0xa3, kvm_enable_cap);
+ioctl_iow_nr!(KVM_DIRTY_TLB, KVMIO, 0xaa, kvm_dirty_tlb);
+ioctl_iow_nr!(KVM_GET_ONE_REG, KVMIO, 0xab, kvm_one_reg);
+ioctl_iow_nr!(KVM_SET_ONE_REG, KVMIO, 0xac, kvm_one_reg);
+ioctl_io_nr!(KVM_KVMCLOCK_CTRL, KVMIO, 0xad);
+ioctl_iowr_nr!(KVM_GET_REG_LIST, KVMIO, 0xb0, kvm_reg_list);
+ioctl_io_nr!(KVM_SMI, KVMIO, 0xb7);
 
 // Along with the common ioctls, we reexport the ioctls of the current
 // platform.