Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp2701907ybl; Mon, 19 Aug 2019 06:19:14 -0700 (PDT) X-Google-Smtp-Source: APXvYqwKn54t+jqe2rQm8ZtykBmYtveEabQj6whUgb+AngiB8yS9PBnPavutYDdN+U9I2IlYgT8/ X-Received: by 2002:a17:902:e30d:: with SMTP id cg13mr22638015plb.173.1566220754076; Mon, 19 Aug 2019 06:19:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1566220754; cv=none; d=google.com; s=arc-20160816; b=vdlg4DPy4HWZn9JWEOUDcMwrWE34Q4VZ7DQWeKY/lTgg/HhGrLh8C1EK7kcYKqvr7o 61pl9zcXx/PttWREm5U0kl8PfVqknWxtBQH02C7sZPS6mKwHOurXybw1vgxn6XEKZBkj A4Amw6LFKNR4zxkAumWPCmyd3Do+hoe419WdcqG4u6pezaFTox6evoR0Tl1tcyGQpGnL RCq/qaAJmba8B2H90B87Os66290NCXTfZuCZ1Vs8anztvjXzp8A0lBK3LF53AhDf7yz9 nsqptL9bvAt9zUeoss+qImmykJaWALGwTCmQWBUm6oA0KPimWlWD9pBZUcN/ehvo23p8 9sTQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=aZ+5nrs0LMjDpHKkki7nAhcxgYSF9NknvkkgLtDTGPg=; b=o9h1KLQl2C2Yhoh6yMCl3X3jTh+wdVooyFLV4geOZDeCemuQJMdfO4rHapEcZPO0pQ XEYu5VtJb1n1UzYHKmcr3m58/iYXrXiiualJL9hPzPw29gQEk57M9GnHyGQOgRa2iPo2 l24TIHJilv6IXFhL6gEEfSjCEs5bfAHa0m0StO8aZKKaQQ/5Sb0if06I53A1auoRmqzW tXvA0nQIS/BUhCrow8RKOHExxdNr/ay7jvAbdU38ln4myPniR66L/11XwquKcYInQ/bk gHUYRaUwk/uq1G06S5zIWjAi8Npbih9sxKyF18MdxdVqfHDrppyyo5EcTs0LQy8ODquG P7Hw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=DEpiA+AQ; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id bh4si9720961plb.198.2019.08.19.06.18.58; Mon, 19 Aug 2019 06:19:14 -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=@gmail.com header.s=20161025 header.b=DEpiA+AQ; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727744AbfHSNR6 (ORCPT + 99 others); Mon, 19 Aug 2019 09:17:58 -0400 Received: from mail-pl1-f195.google.com ([209.85.214.195]:40905 "EHLO mail-pl1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727332AbfHSNR6 (ORCPT ); Mon, 19 Aug 2019 09:17:58 -0400 Received: by mail-pl1-f195.google.com with SMTP id h3so964615pls.7; Mon, 19 Aug 2019 06:17:57 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=aZ+5nrs0LMjDpHKkki7nAhcxgYSF9NknvkkgLtDTGPg=; b=DEpiA+AQKlaUh3RF+A0tZaaCuPvzPryNNQGETkC05fPPFgLCBJEVRfWOmKQ1ziEoFj 0PubyaCZZn8frFwQksrf7erQSUkvwLZimSyuB+vonblyBB5nok7c0gNHiIWcvv3r9M1U fKeX+BcrCw+VCzfoHHgdZ+4h7rP+p9Olgg5kKt5LrMu0XjnoJAEIAXMzx3/d/9wCe7Oc G9BfFkm9svfl2GFqBSa3xBvAAa+jRnSSNGS7JUYdo/Dan45GObCNhtA+C6FcaeAxwGXW ASlz1auo0fqa0wQKb0hbbpEOyfyFH5IUoK+iVAcV1fVy7J8KCdieL8ezBoq3F9r2lgrD 1T2g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=aZ+5nrs0LMjDpHKkki7nAhcxgYSF9NknvkkgLtDTGPg=; b=WD1TjZgcHnjWjbSDq5sUm/QBxOMKmcHap02SkzD7B1M14UZon9gQ/eWuH0X5jEWwKO z4iWH61MA+5PUbIrkXbTB0CyxIDWsX8mWs41MrUX4j/7qbDYX2spbyWv+CC51Ho+y5sm tgqFceX6GROWWx5i12BHcnYXcXnBxLKK0Bok8HRf494OxPr4yheopWrdtLisSVLTT18p t+hc2CSpJHvQVuK8TH9s8OOrkzq8qTg4M4GGQRb2rSiBs96nFbKmDlwpAcqq5iYmv/52 LIgDY0SpcKt7LXipM2ZWVhaFSX939Z38nmZTpe8U4kBPsg6EpbGdv3JI7CZqrodsIvCp ++1A== X-Gm-Message-State: APjAAAVEGrOkIaZstyfyx3y3rHjWDziDKFoKQRTbAsVoBetIR1XSlJ1P W6Znomk1ZgS1WVo7m2Z2zC4= X-Received: by 2002:a17:902:b094:: with SMTP id p20mr2016081plr.320.1566220677481; Mon, 19 Aug 2019 06:17:57 -0700 (PDT) Received: from localhost.corp.microsoft.com ([167.220.255.114]) by smtp.googlemail.com with ESMTPSA id h20sm16184329pfq.156.2019.08.19.06.17.52 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Mon, 19 Aug 2019 06:17:56 -0700 (PDT) From: lantianyu1986@gmail.com X-Google-Original-From: Tianyu.Lan@microsoft.com To: pbonzini@redhat.com, rkrcmar@redhat.com, corbet@lwn.net, kys@microsoft.com, haiyangz@microsoft.com, sthemmin@microsoft.com, sashal@kernel.org, tglx@linutronix.de, mingo@redhat.com, bp@alien8.de, hpa@zytor.com, x86@kernel.org, michael.h.kelley@microsoft.com Cc: Tianyu Lan , kvm@vger.kernel.org, linux-doc@vger.kernel.org, linux-hyperv@vger.kernel.org, linux-kernel@vger.kernel.org, vkuznets@redhat.com Subject: [PATCH V3 0/3] KVM/Hyper-V: Add Hyper-V direct tlb flush support Date: Mon, 19 Aug 2019 21:17:34 +0800 Message-Id: <20190819131737.26942-1-Tianyu.Lan@microsoft.com> X-Mailer: git-send-email 2.14.5 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Tianyu Lan This patchset is to add Hyper-V direct tlb support in KVM. Hyper-V in L0 can delegate L1 hypervisor to handle tlb flush request from L2 guest when direct tlb flush is enabled in L1. Patch 2 introduces new cap KVM_CAP_HYPERV_DIRECT_TLBFLUSH to enable feature from user space. User space should enable this feature only when Hyper-V hypervisor capability is exposed to guest and KVM profile is hided. There is a parameter conflict between KVM and Hyper-V hypercall. We hope L2 guest doesn't use KVM hypercall when the feature is enabled. Detail please see comment of new API "KVM_CAP_HYPERV_DIRECT_TLBFLUSH" Change since v2: - Move hv assist page(hv_pa_pg) from struct kvm to struct kvm_hv. Change since v1: - Fix offset issue in the patch 1. - Update description of KVM KVM_CAP_HYPERV_DIRECT_TLBFLUSH. Tianyu Lan (2): x86/Hyper-V: Fix definition of struct hv_vp_assist_page KVM/Hyper-V: Add new KVM cap KVM_CAP_HYPERV_DIRECT_TLBFLUSH Vitaly Kuznetsov (1): KVM/Hyper-V/VMX: Add direct tlb flush support Documentation/virtual/kvm/api.txt | 13 +++++++++++++ arch/x86/include/asm/hyperv-tlfs.h | 24 ++++++++++++++++++----- arch/x86/include/asm/kvm_host.h | 4 ++++ arch/x86/kvm/vmx/evmcs.h | 2 ++ arch/x86/kvm/vmx/vmx.c | 39 ++++++++++++++++++++++++++++++++++++++ arch/x86/kvm/x86.c | 8 ++++++++ include/uapi/linux/kvm.h | 1 + 7 files changed, 86 insertions(+), 5 deletions(-) -- 2.14.5