Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp7151717ybi; Mon, 8 Jul 2019 15:41:23 -0700 (PDT) X-Google-Smtp-Source: APXvYqxeJVCJ8IXPnPx+wUelQ2mZswZi4EliSJcoyZLX9yDf78zCVlJmzqjNa+hMUPGf7HIRotbe X-Received: by 2002:a17:90a:228b:: with SMTP id s11mr27989487pjc.23.1562625683795; Mon, 08 Jul 2019 15:41:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1562625683; cv=none; d=google.com; s=arc-20160816; b=R+S4Ervs9Mu3bwaG0t4nbXXWnVioIclJMK8MdABfQN6F8P0GeWf9bBZNYnQWZ8sksG rs7rkTqkFNAXMBC4eCvyuLbCJUYy2pPBPJ8ONz0wVLIDJml4Q90xAjCP8W9V3wRAtJFp l5acv/nQj3VBZpCEIwfHKGH2wcsOysuUymGnike9CLTnk6c09YOb0kay85NR8KtV0Oxl eWxMJIeIe14Tr14X1lzzSJEEQ9RQCzCgyWCKrS0YIKajoAwVewyNg9diASqdSlKmGe8O 8dggRiUZuLIhJD1OYB7mcWghz2X5/OKRD5EfsS/kbP9R5807nNefSGuR2m7jq7tWFq4m FdqQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=oNIIdA0inq8gD8/8IQP7FxDpExYwkAlA6ZRKcZAYn/c=; b=SB6NEcvwdsh2DiYX1h6UZSgU5KHpL+n32fEotsPd3sowIunTgsR7ZThkgD8XNFF5fQ wiggTymZLvslw9OHvw+FopC0Xnqw5hUybmmuvRYQbakPfhMYLECYio8GpEkFr/sK0WA+ iO+OAVYrFvhgIAldg/CjA40x6vppxzo5gjNMqfxFKTrQ8PSlIri4dqcjGDTFfKjnG3HB vR5W8a39IzDZxwBsraaZPWXlio5Dw/F/KouvjY1qC8CWf8lMt4COwmF42KpRtspRxNE/ DjkjpQgmwspk8NqkK4cjmpKphV8pzYtysGMcO3sIXXOjMcqFrr7CH5TCPaL7JvPFyp4j +3/g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=tfdscly4; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v74si20442784pgb.375.2019.07.08.15.41.09; Mon, 08 Jul 2019 15:41:23 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=tfdscly4; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2403794AbfGHPmh (ORCPT + 99 others); Mon, 8 Jul 2019 11:42:37 -0400 Received: from mail.kernel.org ([198.145.29.99]:42958 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2391084AbfGHPmg (ORCPT ); Mon, 8 Jul 2019 11:42:36 -0400 Received: from quaco.ghostprotocols.net (179-240-135-35.3g.claro.net.br [179.240.135.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 449C0216FD; Mon, 8 Jul 2019 15:42:26 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1562600555; bh=9QjbTOdq9g3tK/ac5CbO1VgIDYm/V3qGsSOxsJIgGvE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=tfdscly4ahJ83nAqGiUSkApns24HPQzx/BnbsNPHuufvrkIoYrjtHd2KbQ+RH/DyH 5J1S+bubBDB35eknSD8AKqprb4DGxBEc5VZmeWJDmPJjCCK9pL4joPa0gijSi4MSwr 6UtkSbW/YJFEAdi5HHubG7AyFfEhYgUQaIfuVxs0= From: Arnaldo Carvalho de Melo To: Ingo Molnar , Thomas Gleixner Cc: Jiri Olsa , Namhyung Kim , Clark Williams , linux-kernel@vger.kernel.org, linux-perf-users@vger.kernel.org, Arnaldo Carvalho de Melo , Adrian Hunter , Dave Martin , Liran Alon , Paolo Bonzini , Will Deacon Subject: [PATCH 1/8] tools arch kvm: Sync kvm headers with the kernel sources Date: Mon, 8 Jul 2019 12:42:00 -0300 Message-Id: <20190708154207.11403-2-acme@kernel.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190708154207.11403-1-acme@kernel.org> References: <20190708154207.11403-1-acme@kernel.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Arnaldo Carvalho de Melo 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 Cc: Dave Martin Cc: Jiri Olsa Cc: Liran Alon Cc: Namhyung Kim Cc: Paolo Bonzini Cc: Will Deacon Link: https://lkml.kernel.org/n/tip-1cdbq5ulr4d6cx3iv2ye5wdv@git.kernel.org Signed-off-by: Arnaldo Carvalho de Melo --- tools/arch/arm64/include/uapi/asm/kvm.h | 7 ++++++ 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 { KVM_REG_SIZE_U256 | \ ((i) & (KVM_ARM64_SVE_MAX_SLICES - 1))) +/* + * Register values for KVM_REG_ARM64_SVE_ZREG(), KVM_REG_ARM64_SVE_PREG() and + * KVM_REG_ARM64_SVE_FFR() are represented in memory in an endianness- + * invariant layout which differs from the layout used for the FPSIMD + * V-registers on big-endian systems: see sigcontext.h for more explanation. + */ + #define KVM_ARM64_SVE_VQ_MIN __SVE_VQ_MIN #define KVM_ARM64_SVE_VQ_MAX __SVE_VQ_MAX 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 { #define KVM_X86_QUIRK_LAPIC_MMIO_HOLE (1 << 2) #define KVM_X86_QUIRK_OUT_7E_INC_RIP (1 << 3) +#define KVM_STATE_NESTED_FORMAT_VMX 0 +#define KVM_STATE_NESTED_FORMAT_SVM 1 /* unused */ + #define KVM_STATE_NESTED_GUEST_MODE 0x00000001 #define KVM_STATE_NESTED_RUN_PENDING 0x00000002 #define KVM_STATE_NESTED_EVMCS 0x00000004 @@ -390,7 +393,14 @@ struct kvm_sync_regs { #define KVM_STATE_NESTED_SMM_GUEST_MODE 0x00000001 #define KVM_STATE_NESTED_SMM_VMXON 0x00000002 -struct kvm_vmx_nested_state { +#define KVM_STATE_NESTED_VMX_VMCS_SIZE 0x1000 + +struct kvm_vmx_nested_state_data { + __u8 vmcs12[KVM_STATE_NESTED_VMX_VMCS_SIZE]; + __u8 shadow_vmcs12[KVM_STATE_NESTED_VMX_VMCS_SIZE]; +}; + +struct kvm_vmx_nested_state_hdr { __u64 vmxon_pa; __u64 vmcs12_pa; @@ -401,24 +411,25 @@ struct kvm_vmx_nested_state { /* for KVM_CAP_NESTED_STATE */ struct kvm_nested_state { - /* KVM_STATE_* flags */ __u16 flags; - - /* 0 for VMX, 1 for SVM. */ __u16 format; - - /* 128 for SVM, 128 + VMCS size for VMX. */ __u32 size; union { - /* VMXON, VMCS */ - struct kvm_vmx_nested_state vmx; + struct kvm_vmx_nested_state_hdr vmx; /* Pad the header to 128 bytes. */ __u8 pad[120]; - }; + } hdr; - __u8 data[0]; + /* + * Define data region as 0 bytes to preserve backwards-compatability + * to old definition of kvm_nested_state in order to avoid changing + * KVM_{GET,PUT}_NESTED_STATE ioctl values. + */ + union { + struct kvm_vmx_nested_state_data vmx[0]; + } data; }; #endif /* _ASM_X86_KVM_H */ -- 2.20.1