Received: by 2002:ac0:a591:0:0:0:0:0 with SMTP id m17-v6csp1629274imm; Fri, 6 Jul 2018 03:44:13 -0700 (PDT) X-Google-Smtp-Source: AAOMgpfn5qa6zyoHsopdaxmKV3nIMkbLgSEF/+BWIOEw4Yl+fntYEJnbvf+3Syg7jyPfhQ3ig1AG X-Received: by 2002:a65:40ca:: with SMTP id u10-v6mr4220048pgp.2.1530873853859; Fri, 06 Jul 2018 03:44:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530873853; cv=none; d=google.com; s=arc-20160816; b=CGOvC2NAlwUExEyxbdbmH6PWcyzTtgzvLY5tCZ3nimxQlJoj5gfGE+Ps5NZb4uQXOV WcGhn0jqsv4LeEYlYmmq7tEArrndo7gWNENpB1rAIUCIZ/2sWcxp82/iNhxKZG6v21X+ 5BXSdMflGhqfL/1X+1KMuFuxXdGYcgDl/W4cazH7jkNq0VLiA4S94a469UVJR27kIYN7 g7ercC2uk8po+WPxBO3ZiRxqcQfLFFIyTwCNHsbNrSbJ5jene6WqKh/FEfch6nYFvuNX XGTmY87NfGUvyVubn4Vn2h1W8h3jL3z23WClE9W4kYpz7/KCkmp1KSJlIQ+JXMS6UeAK cjfQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-disposition :content-transfer-encoding:mime-version:robot-unsubscribe:robot-id :git-commit-id:subject:to:references:in-reply-to:reply-to:cc :message-id:from:date:arc-authentication-results; bh=fPkF/XPysHGbpbl2uSJjSDuwPEwD7WyOpORO7zwClmc=; b=JW6N6IOF0npTywBzk8OxcmZqdBCFvdwzcdhpLQSGZcQgH78nVkiPmqYLeHDmeGR3ec td/QRNKMMSdL7Kyh+rdBWldNuJWLNlX7jcoiWymfmtm1et45wGOu5COF3yiLLBbMBAmN uC/NN+6P1n3Hhnj7E2S0VtHV1RbiLen58Dc9M+2ylpesjEVs3bIHSOCbcekxEZHqyDsq nfphNyrvBvnIj0QOii2FR5iv1YQ2L+QBTykP9uAdB6BNtSN93u4aCwGUnnTa3HJdNzR1 yL8704ft1Dn042alCzYCZwfWtjKH5iF5qcHES4E/5LmuGzB8v6QUI7n6r6N3cgu7p0eG RAPQ== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 67-v6si7533682pgb.107.2018.07.06.03.43.58; Fri, 06 Jul 2018 03:44:13 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753864AbeGFKnH (ORCPT + 99 others); Fri, 6 Jul 2018 06:43:07 -0400 Received: from terminus.zytor.com ([198.137.202.136]:53503 "EHLO terminus.zytor.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753522AbeGFKnF (ORCPT ); Fri, 6 Jul 2018 06:43:05 -0400 Received: from terminus.zytor.com (localhost [127.0.0.1]) by terminus.zytor.com (8.15.2/8.15.2) with ESMTPS id w66Agufh1435305 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NO); Fri, 6 Jul 2018 03:42:56 -0700 Received: (from tipbot@localhost) by terminus.zytor.com (8.15.2/8.15.2/Submit) id w66Aguo21435302; Fri, 6 Jul 2018 03:42:56 -0700 Date: Fri, 6 Jul 2018 03:42:56 -0700 X-Authentication-Warning: terminus.zytor.com: tipbot set sender to tipbot@zytor.com using -f From: "tip-bot for K. Y. Srinivasan" Message-ID: Cc: hpa@zytor.com, linux-kernel@vger.kernel.org, tglx@linutronix.de, mingo@kernel.org, kys@microsoft.com, mikelley@microsoft.com Reply-To: hpa@zytor.com, linux-kernel@vger.kernel.org, tglx@linutronix.de, kys@microsoft.com, mikelley@microsoft.com, mingo@kernel.org In-Reply-To: <20180703230155.15160-1-kys@linuxonhyperv.com> References: <20180703230155.15160-1-kys@linuxonhyperv.com> To: linux-tip-commits@vger.kernel.org Subject: [tip:x86/hyperv] x86/hyper-v: Fix the circular dependency in IPI enlightenment Git-Commit-ID: 1268ed0c474a5c8f165ef386f3310521b5e00e27 X-Mailer: tip-git-log-daemon Robot-ID: Robot-Unsubscribe: Contact to get blacklisted from these emails MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain; charset=UTF-8 Content-Disposition: inline X-Spam-Status: No, score=-2.9 required=5.0 tests=ALL_TRUSTED,BAYES_00, T_DATE_IN_FUTURE_96_Q autolearn=ham autolearn_force=no version=3.4.1 X-Spam-Checker-Version: SpamAssassin 3.4.1 (2015-04-28) on terminus.zytor.com Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Commit-ID: 1268ed0c474a5c8f165ef386f3310521b5e00e27 Gitweb: https://git.kernel.org/tip/1268ed0c474a5c8f165ef386f3310521b5e00e27 Author: K. Y. Srinivasan AuthorDate: Tue, 3 Jul 2018 16:01:55 -0700 Committer: Thomas Gleixner CommitDate: Fri, 6 Jul 2018 12:32:59 +0200 x86/hyper-v: Fix the circular dependency in IPI enlightenment The IPI hypercalls depend on being able to map the Linux notion of CPU ID to the hypervisor's notion of the CPU ID. The array hv_vp_index[] provides this mapping. Code for populating this array depends on the IPI functionality. Break this circular dependency. [ tglx: Use a proper define instead of '-1' with a u32 variable as pointed out by Vitaly ] Fixes: 68bb7bfb7985 ("X86/Hyper-V: Enable IPI enlightenments") Signed-off-by: K. Y. Srinivasan Signed-off-by: Thomas Gleixner Tested-by: Michael Kelley Cc: gregkh@linuxfoundation.org Cc: devel@linuxdriverproject.org Cc: olaf@aepfle.de Cc: apw@canonical.com Cc: jasowang@redhat.com Cc: hpa@zytor.com Cc: sthemmin@microsoft.com Cc: Michael.H.Kelley@microsoft.com Cc: vkuznets@redhat.com Link: https://lkml.kernel.org/r/20180703230155.15160-1-kys@linuxonhyperv.com --- arch/x86/hyperv/hv_apic.c | 5 +++++ arch/x86/hyperv/hv_init.c | 5 ++++- arch/x86/include/asm/mshyperv.h | 5 ++++- 3 files changed, 13 insertions(+), 2 deletions(-) diff --git a/arch/x86/hyperv/hv_apic.c b/arch/x86/hyperv/hv_apic.c index f68855499391..402338365651 100644 --- a/arch/x86/hyperv/hv_apic.c +++ b/arch/x86/hyperv/hv_apic.c @@ -114,6 +114,8 @@ static bool __send_ipi_mask_ex(const struct cpumask *mask, int vector) ipi_arg->vp_set.format = HV_GENERIC_SET_SPARSE_4K; nr_bank = cpumask_to_vpset(&(ipi_arg->vp_set), mask); } + if (nr_bank < 0) + goto ipi_mask_ex_done; if (!nr_bank) ipi_arg->vp_set.format = HV_GENERIC_SET_ALL; @@ -158,6 +160,9 @@ static bool __send_ipi_mask(const struct cpumask *mask, int vector) for_each_cpu(cur_cpu, mask) { vcpu = hv_cpu_number_to_vp_number(cur_cpu); + if (vcpu == VP_INVAL) + goto ipi_mask_done; + /* * This particular version of the IPI hypercall can * only target upto 64 CPUs. diff --git a/arch/x86/hyperv/hv_init.c b/arch/x86/hyperv/hv_init.c index 4c431e1c1eff..1ff420217298 100644 --- a/arch/x86/hyperv/hv_init.c +++ b/arch/x86/hyperv/hv_init.c @@ -265,7 +265,7 @@ void __init hyperv_init(void) { u64 guest_id, required_msrs; union hv_x64_msr_hypercall_contents hypercall_msr; - int cpuhp; + int cpuhp, i; if (x86_hyper_type != X86_HYPER_MS_HYPERV) return; @@ -293,6 +293,9 @@ void __init hyperv_init(void) if (!hv_vp_index) return; + for (i = 0; i < num_possible_cpus(); i++) + hv_vp_index[i] = VP_INVAL; + hv_vp_assist_page = kcalloc(num_possible_cpus(), sizeof(*hv_vp_assist_page), GFP_KERNEL); if (!hv_vp_assist_page) { diff --git a/arch/x86/include/asm/mshyperv.h b/arch/x86/include/asm/mshyperv.h index 3cd14311edfa..5a7375ed5f7c 100644 --- a/arch/x86/include/asm/mshyperv.h +++ b/arch/x86/include/asm/mshyperv.h @@ -9,6 +9,8 @@ #include #include +#define VP_INVAL U32_MAX + struct ms_hyperv_info { u32 features; u32 misc_features; @@ -20,7 +22,6 @@ struct ms_hyperv_info { extern struct ms_hyperv_info ms_hyperv; - /* * Generate the guest ID. */ @@ -281,6 +282,8 @@ static inline int cpumask_to_vpset(struct hv_vpset *vpset, */ for_each_cpu(cpu, cpus) { vcpu = hv_cpu_number_to_vp_number(cpu); + if (vcpu == VP_INVAL) + return -1; vcpu_bank = vcpu / 64; vcpu_offset = vcpu % 64; __set_bit(vcpu_offset, (unsigned long *)