diff options
author | Arnaldo Carvalho de Melo <acme@redhat.com> | 2019-07-06 13:26:40 -0400 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2019-07-06 13:26:40 -0400 |
commit | c499d1f483a99e86a5f712277de7c8fa33a9ec0a (patch) | |
tree | 876163fe41ae98c96192fb465ff06f279cd69159 /tools/arch | |
parent | 69bf4b6b54fb7f52b7ea9ce28d4a360cd5ec956d (diff) |
tools arch kvm: Sync kvm headers with the kernel sources
To pick up the changes from:
41040cf7c5f0 ("arm64/sve: Fix missing SVE/FPSIMD endianness conversions")
6ca00dfafda7 ("KVM: x86: Modify struct kvm_nested_state to have explicit fields for data")
None entail changes in tooling.
This silences these tools/perf build warnings:
Warning: Kernel ABI header at 'tools/arch/x86/include/uapi/asm/kvm.h' differs from latest version at 'arch/x86/include/uapi/asm/kvm.h'
diff -u tools/arch/x86/include/uapi/asm/kvm.h arch/x86/include/uapi/asm/kvm.h
Warning: Kernel ABI header at 'tools/arch/arm64/include/uapi/asm/kvm.h' differs from latest version at 'arch/arm64/include/uapi/asm/kvm.h'
diff -u tools/arch/arm64/include/uapi/asm/kvm.h arch/arm64/include/uapi/asm/kvm.h
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Dave Martin <Dave.Martin@arm.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Liran Alon <liran.alon@oracle.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Paolo Bonzini <pbonzini@redhat.com>
Cc: Will Deacon <will.deacon@arm.com>
Link: https://lkml.kernel.org/n/tip-1cdbq5ulr4d6cx3iv2ye5wdv@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/arch')
-rw-r--r-- | tools/arch/arm64/include/uapi/asm/kvm.h | 7 | ||||
-rw-r--r-- | tools/arch/x86/include/uapi/asm/kvm.h | 31 |
2 files changed, 28 insertions, 10 deletions
diff --git a/tools/arch/arm64/include/uapi/asm/kvm.h b/tools/arch/arm64/include/uapi/asm/kvm.h index 7b7ac0f6cec9..d819a3e8b552 100644 --- a/tools/arch/arm64/include/uapi/asm/kvm.h +++ b/tools/arch/arm64/include/uapi/asm/kvm.h | |||
@@ -260,6 +260,13 @@ struct kvm_vcpu_events { | |||
260 | KVM_REG_SIZE_U256 | \ | 260 | KVM_REG_SIZE_U256 | \ |
261 | ((i) & (KVM_ARM64_SVE_MAX_SLICES - 1))) | 261 | ((i) & (KVM_ARM64_SVE_MAX_SLICES - 1))) |
262 | 262 | ||
263 | /* | ||
264 | * Register values for KVM_REG_ARM64_SVE_ZREG(), KVM_REG_ARM64_SVE_PREG() and | ||
265 | * KVM_REG_ARM64_SVE_FFR() are represented in memory in an endianness- | ||
266 | * invariant layout which differs from the layout used for the FPSIMD | ||
267 | * V-registers on big-endian systems: see sigcontext.h for more explanation. | ||
268 | */ | ||
269 | |||
263 | #define KVM_ARM64_SVE_VQ_MIN __SVE_VQ_MIN | 270 | #define KVM_ARM64_SVE_VQ_MIN __SVE_VQ_MIN |
264 | #define KVM_ARM64_SVE_VQ_MAX __SVE_VQ_MAX | 271 | #define KVM_ARM64_SVE_VQ_MAX __SVE_VQ_MAX |
265 | 272 | ||
diff --git a/tools/arch/x86/include/uapi/asm/kvm.h b/tools/arch/x86/include/uapi/asm/kvm.h index 24a8cd229df6..d6ab5b4d15e5 100644 --- a/tools/arch/x86/include/uapi/asm/kvm.h +++ b/tools/arch/x86/include/uapi/asm/kvm.h | |||
@@ -383,6 +383,9 @@ struct kvm_sync_regs { | |||
383 | #define KVM_X86_QUIRK_LAPIC_MMIO_HOLE (1 << 2) | 383 | #define KVM_X86_QUIRK_LAPIC_MMIO_HOLE (1 << 2) |
384 | #define KVM_X86_QUIRK_OUT_7E_INC_RIP (1 << 3) | 384 | #define KVM_X86_QUIRK_OUT_7E_INC_RIP (1 << 3) |
385 | 385 | ||
386 | #define KVM_STATE_NESTED_FORMAT_VMX 0 | ||
387 | #define KVM_STATE_NESTED_FORMAT_SVM 1 /* unused */ | ||
388 | |||
386 | #define KVM_STATE_NESTED_GUEST_MODE 0x00000001 | 389 | #define KVM_STATE_NESTED_GUEST_MODE 0x00000001 |
387 | #define KVM_STATE_NESTED_RUN_PENDING 0x00000002 | 390 | #define KVM_STATE_NESTED_RUN_PENDING 0x00000002 |
388 | #define KVM_STATE_NESTED_EVMCS 0x00000004 | 391 | #define KVM_STATE_NESTED_EVMCS 0x00000004 |
@@ -390,7 +393,14 @@ struct kvm_sync_regs { | |||
390 | #define KVM_STATE_NESTED_SMM_GUEST_MODE 0x00000001 | 393 | #define KVM_STATE_NESTED_SMM_GUEST_MODE 0x00000001 |
391 | #define KVM_STATE_NESTED_SMM_VMXON 0x00000002 | 394 | #define KVM_STATE_NESTED_SMM_VMXON 0x00000002 |
392 | 395 | ||
393 | struct kvm_vmx_nested_state { | 396 | #define KVM_STATE_NESTED_VMX_VMCS_SIZE 0x1000 |
397 | |||
398 | struct kvm_vmx_nested_state_data { | ||
399 | __u8 vmcs12[KVM_STATE_NESTED_VMX_VMCS_SIZE]; | ||
400 | __u8 shadow_vmcs12[KVM_STATE_NESTED_VMX_VMCS_SIZE]; | ||
401 | }; | ||
402 | |||
403 | struct kvm_vmx_nested_state_hdr { | ||
394 | __u64 vmxon_pa; | 404 | __u64 vmxon_pa; |
395 | __u64 vmcs12_pa; | 405 | __u64 vmcs12_pa; |
396 | 406 | ||
@@ -401,24 +411,25 @@ struct kvm_vmx_nested_state { | |||
401 | 411 | ||
402 | /* for KVM_CAP_NESTED_STATE */ | 412 | /* for KVM_CAP_NESTED_STATE */ |
403 | struct kvm_nested_state { | 413 | struct kvm_nested_state { |
404 | /* KVM_STATE_* flags */ | ||
405 | __u16 flags; | 414 | __u16 flags; |
406 | |||
407 | /* 0 for VMX, 1 for SVM. */ | ||
408 | __u16 format; | 415 | __u16 format; |
409 | |||
410 | /* 128 for SVM, 128 + VMCS size for VMX. */ | ||
411 | __u32 size; | 416 | __u32 size; |
412 | 417 | ||
413 | union { | 418 | union { |
414 | /* VMXON, VMCS */ | 419 | struct kvm_vmx_nested_state_hdr vmx; |
415 | struct kvm_vmx_nested_state vmx; | ||
416 | 420 | ||
417 | /* Pad the header to 128 bytes. */ | 421 | /* Pad the header to 128 bytes. */ |
418 | __u8 pad[120]; | 422 | __u8 pad[120]; |
419 | }; | 423 | } hdr; |
420 | 424 | ||
421 | __u8 data[0]; | 425 | /* |
426 | * Define data region as 0 bytes to preserve backwards-compatability | ||
427 | * to old definition of kvm_nested_state in order to avoid changing | ||
428 | * KVM_{GET,PUT}_NESTED_STATE ioctl values. | ||
429 | */ | ||
430 | union { | ||
431 | struct kvm_vmx_nested_state_data vmx[0]; | ||
432 | } data; | ||
422 | }; | 433 | }; |
423 | 434 | ||
424 | #endif /* _ASM_X86_KVM_H */ | 435 | #endif /* _ASM_X86_KVM_H */ |