Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp1798512pxa; Thu, 6 Aug 2020 16:40:05 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzSy3XF5t457CP9dd/8+g6oVUb/nkUu0FVFRKo9dEZ9lB95kBRAYb3UfWTjh7ErEx98hC6l X-Received: by 2002:a17:906:a18e:: with SMTP id s14mr6664290ejy.168.1596757205134; Thu, 06 Aug 2020 16:40:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1596757205; cv=none; d=google.com; s=arc-20160816; b=IRS9HmZVI/WIuB0bhcFrTO2RbNW/q+9oDjETzDFult4jUphNMht7FJcbgL39RRzZ2F Mn0Z6VDefLsanotx4qmhHwnmQUPYzhvJFs3HrRA/GOTdp5yOfAXw7C4s3ccmQi6mRRwq ka2LoUfCwMAUzdYaWgp0EcQqg7ATVwlEOTbqH9DCyAyPf3X4qG2YAzWEW0nCHUuW0w/Q cZVOiEKlr+hLa6TJQwn4GkhwziDr+aQ0sztvmA8Cw5aVLF5DxYYzWRqg00dAS7t6rmxL oKjZl1WCMrLXQjyK8f4+HJ2O3yRopKKBa5zvotUnmC4WJXfj4EUQZEKlYtgXRo5lqZ0H ay7w== 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 :robot-unsubscribe:robot-id:message-id:mime-version:references :in-reply-to:cc:subject:to:reply-to:from:dkim-signature :dkim-signature:date; bh=mpe6YTkV44HAJlNIEEmmAavR1L5M4e4miMoT9IbpiR8=; b=jHXFCuqSaPqoEvigZ0naVKrJKIhRxXBmmAyNWn+xkxomxrfafRQUtwhSuj5mrlSOz5 4u1pE6BqSW5ZtBqSLVOS9szlCxIQLOVxuZjQrOyxabNLzJ65OAA9fUMkvPzB4GLipLIC 5CQw6A9v/zMu5cTemSg34Kz6PfaxoDSCMMi0aPblFN/+z6TtTxWrD0T12MBv+ci8N/67 2LO30OyQd9kNzyovlYOdK3X675bIUYyj7Txh5sUBUvRtlCgO7+/lGRl/82NFpmj5qGfw c7v5kwW8oBcjF74h8xkmGrsT6uM2qx/zYFgP6ZHWEtQ34gwJJbt6gN7mbD/LApc8kzYY nEzA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@linutronix.de header.s=2020 header.b="0fj4/Jd5"; dkim=neutral (no key) header.i=@vger.kernel.org; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id k13si3954846ejr.354.2020.08.06.16.39.42; Thu, 06 Aug 2020 16:40:05 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=fail header.i=@linutronix.de header.s=2020 header.b="0fj4/Jd5"; dkim=neutral (no key) header.i=@vger.kernel.org; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726644AbgHFXjB (ORCPT + 99 others); Thu, 6 Aug 2020 19:39:01 -0400 Received: from Galois.linutronix.de ([193.142.43.55]:60908 "EHLO galois.linutronix.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726450AbgHFXit (ORCPT ); Thu, 6 Aug 2020 19:38:49 -0400 Date: Thu, 06 Aug 2020 23:38:47 -0000 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1596757127; h=from:from:sender:sender:reply-to:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=mpe6YTkV44HAJlNIEEmmAavR1L5M4e4miMoT9IbpiR8=; b=0fj4/Jd5BbZPGwf3L7GlhUiQkm48zILc8QUremzOBtu+Xm+HdNFxOGP7L2s+KjOgETRny2 h56Ovvwz5szuWVuVAbPCiCmbJj7HyXu+Hcp+JX/B6rdWSodwJkohfLkc2ajD5To9znomhX pSKJP8m3OI+hwNJylj4GMOhkXzcwBeQMWql5NKKUEuhtFKm8VdEIKD9pmtANnENWPyA38w zm3B035Xffw7jqxhkZ/sfVGN3q2kgzf7/vhHfV6nUIA/arL8yPGplj9GhgPDpD7UMhskay eCrcvFJKguAc0K7cn8oKukI1KZA9STPuhzqf/z8jX2+myWBVaHf+TFH7BR1qtg== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1596757127; h=from:from:sender:sender:reply-to:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=mpe6YTkV44HAJlNIEEmmAavR1L5M4e4miMoT9IbpiR8=; b=RtXLoRvfm52g5tI4i3o+EVeIRkEiI04qkWo3INjIMhWo98nU6wYlhq/a7G7FzUT6Vpjldj DyZFpG9lNBC6sWBA== From: "tip-bot2 for Shuo Liu" Reply-to: linux-kernel@vger.kernel.org To: linux-tip-commits@vger.kernel.org Subject: [tip: x86/urgent] x86/acrn: Allow ACRN guest to use X2APIC mode Cc: Yakui Zhao , Shuo Liu , Ingo Molnar , Reinette Chatre , x86 , LKML In-Reply-To: <20200806113802.9325-1-shuo.a.liu@intel.com> References: <20200806113802.9325-1-shuo.a.liu@intel.com> MIME-Version: 1.0 Message-ID: <159675712730.3192.10606013510070138850.tip-bot2@tip-bot2> Robot-ID: Robot-Unsubscribe: Contact to get blacklisted from these emails Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The following commit has been merged into the x86/urgent branch of tip: Commit-ID: 86d709ce30eaa65706090865662a08d7bdd30c54 Gitweb: https://git.kernel.org/tip/86d709ce30eaa65706090865662a08d7bdd30c54 Author: Shuo Liu AuthorDate: Thu, 06 Aug 2020 19:38:02 +08:00 Committer: Ingo Molnar CommitterDate: Fri, 07 Aug 2020 01:32:00 +02:00 x86/acrn: Allow ACRN guest to use X2APIC mode The ACRN Hypervisor did not support x2APIC and thus x2APIC support was disabled by always returning false when VM checked for x2APIC support. ACRN received full support of x2APIC and exports the capability through CPUID feature bits. Let VM decide if it needs to switch to x2APIC mode according to CPUID features. Originally-by: Yakui Zhao Signed-off-by: Shuo Liu Signed-off-by: Ingo Molnar Reviewed-by: Reinette Chatre Link: https://lore.kernel.org/r/20200806113802.9325-1-shuo.a.liu@intel.com --- arch/x86/kernel/cpu/acrn.c | 8 ++------ 1 file changed, 2 insertions(+), 6 deletions(-) diff --git a/arch/x86/kernel/cpu/acrn.c b/arch/x86/kernel/cpu/acrn.c index 1da9b1c..3b08cdf 100644 --- a/arch/x86/kernel/cpu/acrn.c +++ b/arch/x86/kernel/cpu/acrn.c @@ -11,6 +11,7 @@ #include #include +#include #include #include #include @@ -29,12 +30,7 @@ static void __init acrn_init_platform(void) static bool acrn_x2apic_available(void) { - /* - * x2apic is not supported for now. Future enablement will have to check - * X86_FEATURE_X2APIC to determine whether x2apic is supported in the - * guest. - */ - return false; + return boot_cpu_has(X86_FEATURE_X2APIC); } static void (*acrn_intr_handler)(void);