Path: blob/master/tools/testing/selftests/kvm/include/x86/hyperv.h
49473 views
/* SPDX-License-Identifier: GPL-2.0 */1/*2* Copyright (C) 2021, Red Hat, Inc.3*/45#ifndef SELFTEST_KVM_HYPERV_H6#define SELFTEST_KVM_HYPERV_H78#include "processor.h"910#define HYPERV_CPUID_VENDOR_AND_MAX_FUNCTIONS 0x4000000011#define HYPERV_CPUID_INTERFACE 0x4000000112#define HYPERV_CPUID_VERSION 0x4000000213#define HYPERV_CPUID_FEATURES 0x4000000314#define HYPERV_CPUID_ENLIGHTMENT_INFO 0x4000000415#define HYPERV_CPUID_IMPLEMENT_LIMITS 0x4000000516#define HYPERV_CPUID_CPU_MANAGEMENT_FEATURES 0x4000000717#define HYPERV_CPUID_NESTED_FEATURES 0x4000000A18#define HYPERV_CPUID_SYNDBG_VENDOR_AND_MAX_FUNCTIONS 0x4000008019#define HYPERV_CPUID_SYNDBG_INTERFACE 0x4000008120#define HYPERV_CPUID_SYNDBG_PLATFORM_CAPABILITIES 0x400000822122#define HV_X64_MSR_GUEST_OS_ID 0x4000000023#define HV_X64_MSR_HYPERCALL 0x4000000124#define HV_X64_MSR_VP_INDEX 0x4000000225#define HV_X64_MSR_RESET 0x4000000326#define HV_X64_MSR_VP_RUNTIME 0x4000001027#define HV_X64_MSR_TIME_REF_COUNT 0x4000002028#define HV_X64_MSR_REFERENCE_TSC 0x4000002129#define HV_X64_MSR_TSC_FREQUENCY 0x4000002230#define HV_X64_MSR_APIC_FREQUENCY 0x4000002331#define HV_X64_MSR_EOI 0x4000007032#define HV_X64_MSR_ICR 0x4000007133#define HV_X64_MSR_TPR 0x4000007234#define HV_X64_MSR_VP_ASSIST_PAGE 0x4000007335#define HV_X64_MSR_SCONTROL 0x4000008036#define HV_X64_MSR_SVERSION 0x4000008137#define HV_X64_MSR_SIEFP 0x4000008238#define HV_X64_MSR_SIMP 0x4000008339#define HV_X64_MSR_EOM 0x4000008440#define HV_X64_MSR_SINT0 0x4000009041#define HV_X64_MSR_SINT1 0x4000009142#define HV_X64_MSR_SINT2 0x4000009243#define HV_X64_MSR_SINT3 0x4000009344#define HV_X64_MSR_SINT4 0x4000009445#define HV_X64_MSR_SINT5 0x4000009546#define HV_X64_MSR_SINT6 0x4000009647#define HV_X64_MSR_SINT7 0x4000009748#define HV_X64_MSR_SINT8 0x4000009849#define HV_X64_MSR_SINT9 0x4000009950#define HV_X64_MSR_SINT10 0x4000009A51#define HV_X64_MSR_SINT11 0x4000009B52#define HV_X64_MSR_SINT12 0x4000009C53#define HV_X64_MSR_SINT13 0x4000009D54#define HV_X64_MSR_SINT14 0x4000009E55#define HV_X64_MSR_SINT15 0x4000009F56#define HV_X64_MSR_STIMER0_CONFIG 0x400000B057#define HV_X64_MSR_STIMER0_COUNT 0x400000B158#define HV_X64_MSR_STIMER1_CONFIG 0x400000B259#define HV_X64_MSR_STIMER1_COUNT 0x400000B360#define HV_X64_MSR_STIMER2_CONFIG 0x400000B461#define HV_X64_MSR_STIMER2_COUNT 0x400000B562#define HV_X64_MSR_STIMER3_CONFIG 0x400000B663#define HV_X64_MSR_STIMER3_COUNT 0x400000B764#define HV_X64_MSR_GUEST_IDLE 0x400000F065#define HV_X64_MSR_CRASH_P0 0x4000010066#define HV_X64_MSR_CRASH_P1 0x4000010167#define HV_X64_MSR_CRASH_P2 0x4000010268#define HV_X64_MSR_CRASH_P3 0x4000010369#define HV_X64_MSR_CRASH_P4 0x4000010470#define HV_X64_MSR_CRASH_CTL 0x4000010571#define HV_X64_MSR_REENLIGHTENMENT_CONTROL 0x4000010672#define HV_X64_MSR_TSC_EMULATION_CONTROL 0x4000010773#define HV_X64_MSR_TSC_EMULATION_STATUS 0x4000010874#define HV_X64_MSR_TSC_INVARIANT_CONTROL 0x400001187576#define HV_X64_MSR_SYNDBG_CONTROL 0x400000F177#define HV_X64_MSR_SYNDBG_STATUS 0x400000F278#define HV_X64_MSR_SYNDBG_SEND_BUFFER 0x400000F379#define HV_X64_MSR_SYNDBG_RECV_BUFFER 0x400000F480#define HV_X64_MSR_SYNDBG_PENDING_BUFFER 0x400000F581#define HV_X64_MSR_SYNDBG_OPTIONS 0x400000FF8283/* HYPERV_CPUID_FEATURES.EAX */84#define HV_MSR_VP_RUNTIME_AVAILABLE \85KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EAX, 0)86#define HV_MSR_TIME_REF_COUNT_AVAILABLE \87KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EAX, 1)88#define HV_MSR_SYNIC_AVAILABLE \89KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EAX, 2)90#define HV_MSR_SYNTIMER_AVAILABLE \91KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EAX, 3)92#define HV_MSR_APIC_ACCESS_AVAILABLE \93KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EAX, 4)94#define HV_MSR_HYPERCALL_AVAILABLE \95KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EAX, 5)96#define HV_MSR_VP_INDEX_AVAILABLE \97KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EAX, 6)98#define HV_MSR_RESET_AVAILABLE \99KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EAX, 7)100#define HV_MSR_STAT_PAGES_AVAILABLE \101KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EAX, 8)102#define HV_MSR_REFERENCE_TSC_AVAILABLE \103KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EAX, 9)104#define HV_MSR_GUEST_IDLE_AVAILABLE \105KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EAX, 10)106#define HV_ACCESS_FREQUENCY_MSRS \107KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EAX, 11)108#define HV_ACCESS_REENLIGHTENMENT \109KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EAX, 13)110#define HV_ACCESS_TSC_INVARIANT \111KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EAX, 15)112113/* HYPERV_CPUID_FEATURES.EBX */114#define HV_CREATE_PARTITIONS \115KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EBX, 0)116#define HV_ACCESS_PARTITION_ID \117KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EBX, 1)118#define HV_ACCESS_MEMORY_POOL \119KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EBX, 2)120#define HV_ADJUST_MESSAGE_BUFFERS \121KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EBX, 3)122#define HV_POST_MESSAGES \123KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EBX, 4)124#define HV_SIGNAL_EVENTS \125KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EBX, 5)126#define HV_CREATE_PORT \127KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EBX, 6)128#define HV_CONNECT_PORT \129KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EBX, 7)130#define HV_ACCESS_STATS \131KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EBX, 8)132#define HV_DEBUGGING \133KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EBX, 11)134#define HV_CPU_MANAGEMENT \135KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EBX, 12)136#define HV_ENABLE_EXTENDED_HYPERCALLS \137KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EBX, 20)138#define HV_ISOLATION \139KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EBX, 22)140141/* HYPERV_CPUID_FEATURES.EDX */142#define HV_X64_MWAIT_AVAILABLE \143KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EDX, 0)144#define HV_X64_GUEST_DEBUGGING_AVAILABLE \145KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EDX, 1)146#define HV_X64_PERF_MONITOR_AVAILABLE \147KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EDX, 2)148#define HV_X64_CPU_DYNAMIC_PARTITIONING_AVAILABLE \149KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EDX, 3)150#define HV_X64_HYPERCALL_XMM_INPUT_AVAILABLE \151KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EDX, 4)152#define HV_X64_GUEST_IDLE_STATE_AVAILABLE \153KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EDX, 5)154#define HV_FEATURE_FREQUENCY_MSRS_AVAILABLE \155KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EDX, 8)156#define HV_FEATURE_GUEST_CRASH_MSR_AVAILABLE \157KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EDX, 10)158#define HV_FEATURE_DEBUG_MSRS_AVAILABLE \159KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EDX, 11)160#define HV_STIMER_DIRECT_MODE_AVAILABLE \161KVM_X86_CPU_FEATURE(HYPERV_CPUID_FEATURES, 0, EDX, 19)162163/* HYPERV_CPUID_ENLIGHTMENT_INFO.EAX */164#define HV_X64_AS_SWITCH_RECOMMENDED \165KVM_X86_CPU_FEATURE(HYPERV_CPUID_ENLIGHTMENT_INFO, 0, EAX, 0)166#define HV_X64_LOCAL_TLB_FLUSH_RECOMMENDED \167KVM_X86_CPU_FEATURE(HYPERV_CPUID_ENLIGHTMENT_INFO, 0, EAX, 1)168#define HV_X64_REMOTE_TLB_FLUSH_RECOMMENDED \169KVM_X86_CPU_FEATURE(HYPERV_CPUID_ENLIGHTMENT_INFO, 0, EAX, 2)170#define HV_X64_APIC_ACCESS_RECOMMENDED \171KVM_X86_CPU_FEATURE(HYPERV_CPUID_ENLIGHTMENT_INFO, 0, EAX, 3)172#define HV_X64_SYSTEM_RESET_RECOMMENDED \173KVM_X86_CPU_FEATURE(HYPERV_CPUID_ENLIGHTMENT_INFO, 0, EAX, 4)174#define HV_X64_RELAXED_TIMING_RECOMMENDED \175KVM_X86_CPU_FEATURE(HYPERV_CPUID_ENLIGHTMENT_INFO, 0, EAX, 5)176#define HV_DEPRECATING_AEOI_RECOMMENDED \177KVM_X86_CPU_FEATURE(HYPERV_CPUID_ENLIGHTMENT_INFO, 0, EAX, 9)178#define HV_X64_CLUSTER_IPI_RECOMMENDED \179KVM_X86_CPU_FEATURE(HYPERV_CPUID_ENLIGHTMENT_INFO, 0, EAX, 10)180#define HV_X64_EX_PROCESSOR_MASKS_RECOMMENDED \181KVM_X86_CPU_FEATURE(HYPERV_CPUID_ENLIGHTMENT_INFO, 0, EAX, 11)182#define HV_X64_ENLIGHTENED_VMCS_RECOMMENDED \183KVM_X86_CPU_FEATURE(HYPERV_CPUID_ENLIGHTMENT_INFO, 0, EAX, 14)184185/* HYPERV_CPUID_NESTED_FEATURES.EAX */186#define HV_X64_NESTED_DIRECT_FLUSH \187KVM_X86_CPU_FEATURE(HYPERV_CPUID_NESTED_FEATURES, 0, EAX, 17)188#define HV_X64_NESTED_GUEST_MAPPING_FLUSH \189KVM_X86_CPU_FEATURE(HYPERV_CPUID_NESTED_FEATURES, 0, EAX, 18)190#define HV_X64_NESTED_MSR_BITMAP \191KVM_X86_CPU_FEATURE(HYPERV_CPUID_NESTED_FEATURES, 0, EAX, 19)192193/* HYPERV_CPUID_NESTED_FEATURES.EBX */194#define HV_X64_NESTED_EVMCS1_PERF_GLOBAL_CTRL \195KVM_X86_CPU_FEATURE(HYPERV_CPUID_NESTED_FEATURES, 0, EBX, 0)196197/* HYPERV_CPUID_SYNDBG_PLATFORM_CAPABILITIES.EAX */198#define HV_X64_SYNDBG_CAP_ALLOW_KERNEL_DEBUGGING \199KVM_X86_CPU_FEATURE(HYPERV_CPUID_SYNDBG_PLATFORM_CAPABILITIES, 0, EAX, 1)200201/* Hypercalls */202#define HVCALL_FLUSH_VIRTUAL_ADDRESS_SPACE 0x0002203#define HVCALL_FLUSH_VIRTUAL_ADDRESS_LIST 0x0003204#define HVCALL_NOTIFY_LONG_SPIN_WAIT 0x0008205#define HVCALL_SEND_IPI 0x000b206#define HVCALL_FLUSH_VIRTUAL_ADDRESS_SPACE_EX 0x0013207#define HVCALL_FLUSH_VIRTUAL_ADDRESS_LIST_EX 0x0014208#define HVCALL_SEND_IPI_EX 0x0015209#define HVCALL_GET_PARTITION_ID 0x0046210#define HVCALL_DEPOSIT_MEMORY 0x0048211#define HVCALL_CREATE_VP 0x004e212#define HVCALL_GET_VP_REGISTERS 0x0050213#define HVCALL_SET_VP_REGISTERS 0x0051214#define HVCALL_POST_MESSAGE 0x005c215#define HVCALL_SIGNAL_EVENT 0x005d216#define HVCALL_POST_DEBUG_DATA 0x0069217#define HVCALL_RETRIEVE_DEBUG_DATA 0x006a218#define HVCALL_RESET_DEBUG_SESSION 0x006b219#define HVCALL_ADD_LOGICAL_PROCESSOR 0x0076220#define HVCALL_MAP_DEVICE_INTERRUPT 0x007c221#define HVCALL_UNMAP_DEVICE_INTERRUPT 0x007d222#define HVCALL_RETARGET_INTERRUPT 0x007e223#define HVCALL_FLUSH_GUEST_PHYSICAL_ADDRESS_SPACE 0x00af224#define HVCALL_FLUSH_GUEST_PHYSICAL_ADDRESS_LIST 0x00b0225226/* Extended hypercalls */227#define HV_EXT_CALL_QUERY_CAPABILITIES 0x8001228229#define HV_FLUSH_ALL_PROCESSORS BIT(0)230#define HV_FLUSH_ALL_VIRTUAL_ADDRESS_SPACES BIT(1)231#define HV_FLUSH_NON_GLOBAL_MAPPINGS_ONLY BIT(2)232#define HV_FLUSH_USE_EXTENDED_RANGE_FORMAT BIT(3)233234/* hypercall status code */235#define HV_STATUS_SUCCESS 0236#define HV_STATUS_INVALID_HYPERCALL_CODE 2237#define HV_STATUS_INVALID_HYPERCALL_INPUT 3238#define HV_STATUS_INVALID_ALIGNMENT 4239#define HV_STATUS_INVALID_PARAMETER 5240#define HV_STATUS_ACCESS_DENIED 6241#define HV_STATUS_OPERATION_DENIED 8242#define HV_STATUS_INSUFFICIENT_MEMORY 11243#define HV_STATUS_INVALID_PORT_ID 17244#define HV_STATUS_INVALID_CONNECTION_ID 18245#define HV_STATUS_INSUFFICIENT_BUFFERS 19246247/* hypercall options */248#define HV_HYPERCALL_FAST_BIT BIT(16)249#define HV_HYPERCALL_VARHEAD_OFFSET 17250#define HV_HYPERCALL_REP_COMP_OFFSET 32251252/*253* Issue a Hyper-V hypercall. Returns exception vector raised or 0, 'hv_status'254* is set to the hypercall status (if no exception occurred).255*/256static inline uint8_t __hyperv_hypercall(u64 control, vm_vaddr_t input_address,257vm_vaddr_t output_address,258uint64_t *hv_status)259{260uint64_t error_code;261uint8_t vector;262263/* Note both the hypercall and the "asm safe" clobber r9-r11. */264asm volatile("mov %[output_address], %%r8\n\t"265KVM_ASM_SAFE("vmcall")266: "=a" (*hv_status),267"+c" (control), "+d" (input_address),268KVM_ASM_SAFE_OUTPUTS(vector, error_code)269: [output_address] "r"(output_address),270"a" (-EFAULT)271: "cc", "memory", "r8", KVM_ASM_SAFE_CLOBBERS);272return vector;273}274275/* Issue a Hyper-V hypercall and assert that it succeeded. */276static inline void hyperv_hypercall(u64 control, vm_vaddr_t input_address,277vm_vaddr_t output_address)278{279uint64_t hv_status;280uint8_t vector;281282vector = __hyperv_hypercall(control, input_address, output_address, &hv_status);283284GUEST_ASSERT(!vector);285GUEST_ASSERT((hv_status & 0xffff) == 0);286}287288/* Write 'Fast' hypercall input 'data' to the first 'n_sse_regs' SSE regs */289static inline void hyperv_write_xmm_input(void *data, int n_sse_regs)290{291int i;292293for (i = 0; i < n_sse_regs; i++)294write_sse_reg(i, (sse128_t *)(data + sizeof(sse128_t) * i));295}296297/* Proper HV_X64_MSR_GUEST_OS_ID value */298#define HYPERV_LINUX_OS_ID ((u64)0x8100 << 48)299300#define HV_X64_MSR_VP_ASSIST_PAGE 0x40000073301#define HV_X64_MSR_VP_ASSIST_PAGE_ENABLE 0x00000001302#define HV_X64_MSR_VP_ASSIST_PAGE_ADDRESS_SHIFT 12303#define HV_X64_MSR_VP_ASSIST_PAGE_ADDRESS_MASK \304(~((1ull << HV_X64_MSR_VP_ASSIST_PAGE_ADDRESS_SHIFT) - 1))305306struct hv_nested_enlightenments_control {307struct {308__u32 directhypercall:1;309__u32 reserved:31;310} features;311struct {312__u32 reserved;313} hypercallControls;314} __packed;315316/* Define virtual processor assist page structure. */317struct hv_vp_assist_page {318__u32 apic_assist;319__u32 reserved1;320__u64 vtl_control[3];321struct hv_nested_enlightenments_control nested_control;322__u8 enlighten_vmentry;323__u8 reserved2[7];324__u64 current_nested_vmcs;325} __packed;326327extern struct hv_vp_assist_page *current_vp_assist;328329int enable_vp_assist(uint64_t vp_assist_pa, void *vp_assist);330331struct hyperv_test_pages {332/* VP assist page */333void *vp_assist_hva;334uint64_t vp_assist_gpa;335void *vp_assist;336337/* Partition assist page */338void *partition_assist_hva;339uint64_t partition_assist_gpa;340void *partition_assist;341342/* Enlightened VMCS */343void *enlightened_vmcs_hva;344uint64_t enlightened_vmcs_gpa;345void *enlightened_vmcs;346};347348struct hyperv_test_pages *vcpu_alloc_hyperv_test_pages(struct kvm_vm *vm,349vm_vaddr_t *p_hv_pages_gva);350351/* HV_X64_MSR_TSC_INVARIANT_CONTROL bits */352#define HV_INVARIANT_TSC_EXPOSED BIT_ULL(0)353354const struct kvm_cpuid2 *kvm_get_supported_hv_cpuid(void);355const struct kvm_cpuid2 *vcpu_get_supported_hv_cpuid(struct kvm_vcpu *vcpu);356void vcpu_set_hv_cpuid(struct kvm_vcpu *vcpu);357358bool kvm_hv_cpu_has(struct kvm_x86_cpu_feature feature);359360#endif /* !SELFTEST_KVM_HYPERV_H */361362363