summaryrefslogtreecommitdiffstats
path: root/tools/arch
diff options
context:
space:
mode:
authorArnaldo Carvalho de Melo <acme@redhat.com>2019-07-06 13:26:40 -0400
committerArnaldo Carvalho de Melo <acme@redhat.com>2019-07-06 13:26:40 -0400
commitc499d1f483a99e86a5f712277de7c8fa33a9ec0a (patch)
tree876163fe41ae98c96192fb465ff06f279cd69159 /tools/arch
parent69bf4b6b54fb7f52b7ea9ce28d4a360cd5ec956d (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.h7
-rw-r--r--tools/arch/x86/include/uapi/asm/kvm.h31
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
393struct kvm_vmx_nested_state { 396#define KVM_STATE_NESTED_VMX_VMCS_SIZE 0x1000
397
398struct 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
403struct 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 */
403struct kvm_nested_state { 413struct 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 */