Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp459485ybb; Wed, 25 Mar 2020 03:19:21 -0700 (PDT) X-Google-Smtp-Source: ADFU+vtsrz8AxOyUitBp5tOrfUqiLh/jZxm0FwfRnvPkdokW0hN3O6T3aUz91sdzEZFUZL/XqUNe X-Received: by 2002:a4a:919b:: with SMTP id d27mr830650ooh.76.1585131561029; Wed, 25 Mar 2020 03:19:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585131561; cv=none; d=google.com; s=arc-20160816; b=eMXaEVoH8Ktavot6C6Yy33ytPee6J9Ey2PDn40cjAWZNKfrHAFBIyXlbtNPAi5IHXH MHvG6e2AQiqgYwTWe68TmHTw6rZsC/ajAmvaP4UD0FanDHRMfpDmeBt2OoF5D2y+1RIm 6zWpcs+EDMqZB75qKFetKiJA2FxNRwQC95HvrsE5Mum6CHTDxJGYAdBLfggcduS6GeYE 2TfSyc4/VOnNW3FH/XHsRtYJQX+Jt3Hq0Rfi4XIigp/Y/mHf1ytMumzjrhGl//vmh8Ik GybYtuEkLdSci8Aask6cTajmWVNQeNBQmTFCZPN52e7JfiFq75CbmsfBQHFkAsB0sQII yJew== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:from:cc:to:subject :content-transfer-encoding:mime-version:references:in-reply-to :user-agent:date:dkim-signature:dkim-filter; bh=MfCnNAHIm3q3trq9/ponNXXkVrT3z6pQ6mvLieAcQOw=; b=eO0nWpBURp0ucfDUlWw/NOImBq2lkjwqTd+Aa/ugpkfsQ0RsRLVRQuqmDUZ6AoxD/u zL5cEd6SEpH6kbxxOtcBK+QfkQZKETq5mDLiSNYX71SnVBODCERD6bCeTxn3/EKZwvgf 6jnV1Qz4Z3Ay5H/s57Id8RQy0DspTjkbhpJGXSJRW8TupZRRU1nB4fyuekETur2TJa2N qvcAt9gIu/3Oxdemb5bxomZ75nHcBKtPo9c1pDNUli3vS0lPRfzrc2HrygZe+5ByWjw5 E2KOxi3mY/jLbyM1aDUdyd1mkKmibRj8deHx0f6jU7WqZdZsZChxGIbt8pGGrXjbMDU1 9jlw== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@zytor.com header.s=2020032201 header.b=fxxkenOd; 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=fail (p=NONE sp=NONE dis=NONE) header.from=zytor.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w203si9858413oie.193.2020.03.25.03.19.08; Wed, 25 Mar 2020 03:19:21 -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=fail header.i=@zytor.com header.s=2020032201 header.b=fxxkenOd; 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=fail (p=NONE sp=NONE dis=NONE) header.from=zytor.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727556AbgCYKSo (ORCPT + 99 others); Wed, 25 Mar 2020 06:18:44 -0400 Received: from terminus.zytor.com ([198.137.202.136]:53821 "EHLO mail.zytor.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726154AbgCYKSn (ORCPT ); Wed, 25 Mar 2020 06:18:43 -0400 Received: from [IPv6:2601:646:8600:3281:c898:2a71:8b3c:1618] ([IPv6:2601:646:8600:3281:c898:2a71:8b3c:1618]) (authenticated bits=0) by mail.zytor.com (8.15.2/8.15.2) with ESMTPSA id 02PAHWME3424848 (version=TLSv1.3 cipher=TLS_AES_128_GCM_SHA256 bits=128 verify=NO); Wed, 25 Mar 2020 03:17:37 -0700 DKIM-Filter: OpenDKIM Filter v2.11.0 mail.zytor.com 02PAHWME3424848 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=zytor.com; s=2020032201; t=1585131457; bh=MfCnNAHIm3q3trq9/ponNXXkVrT3z6pQ6mvLieAcQOw=; h=Date:In-Reply-To:References:Subject:To:CC:From:From; b=fxxkenOd1GNat/czNUL3g5OX7rYv1s5cxhr6lPNbToyJOvqRI7N1LZTXxvZC+gKat UehNoYWrNtHSkYDW+JU2xUcI90yvB6nEHccigghFwql1IHqxu/U9j8DKpJRdu04Rjp 9ktUPsCqm58jlPoQpdwcyVon+x4AU8ZUw/iRa1XIgQx1+nnoHqLyfZqF7hz/z3fExM jl57k7M2pvzIbBrt1ZXWC6iXhPzr8AvIOp1T887u/+yuMFtvEn+gE59y0hS+3dG4JS A2MgdufY3v2m3DE+ACguCvEw09B7dCNPdj0k8mVioLO1pqpjpR0haiwxweH9oTu9Tl 4+COMkeZeATdg== Date: Wed, 25 Mar 2020 03:17:24 -0700 User-Agent: K-9 Mail for Android In-Reply-To: <20200325101431.12341-1-andrew.cooper3@citrix.com> References: <20200325101431.12341-1-andrew.cooper3@citrix.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: quoted-printable Subject: Re: [PATCH] x86/smpboot: Remove 486-isms from the modern AP boot path To: Andrew Cooper , LKML CC: Thomas Gleixner , Ingo Molnar , Borislav Petkov , x86@kernel.org, Jan Kiszka , James Morris , David Howells , Matthew Garrett , Josh Boyer , Zhenzhong Duan , Steve Wahl , Mike Travis , Dimitri Sivanich , Arnd Bergmann , "Peter Zijlstra (Intel)" , Giovanni Gherdovich , "Rafael J. Wysocki" , Len Brown , Kees Cook , Martin Molnar , Pingfan Liu , jailhouse-dev@googlegroups.com From: hpa@zytor.com Message-ID: <601E644A-B046-4030-B3BD-280ABF15BF53@zytor.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On March 25, 2020 3:14:31 AM PDT, Andrew Cooper wrote: >Linux has an implementation of the Universal Start-up Algorithm (MP >spec, >Appendix B=2E4, Application Processor Startup), which includes >unconditionally >writing to the Bios Data Area and CMOS registers=2E > >The warm reset vector is only necessary in the non-integrated Local >APIC case=2E >UV and Jailhouse already have an opt-out for this behaviour, but >blindly using >the BDA and CMOS on a UEFI or other reduced hardware system isn't >clever=2E > >Drop the warm_reset flag from struct x86_legacy_features, and tie the >warm >vector modifications to the integrated-ness of the Local APIC=2E This >has the >advantage of compiling the warm reset logic out entirely for 64bit >builds=2E > >CC: Thomas Gleixner >CC: Ingo Molnar >CC: Borislav Petkov >CC: "H=2E Peter Anvin" >CC: x86@kernel=2Eorg >CC: Jan Kiszka >CC: James Morris >CC: David Howells >CC: Andrew Cooper >CC: Matthew Garrett >CC: Josh Boyer >CC: Zhenzhong Duan >CC: Steve Wahl >CC: Mike Travis >CC: Dimitri Sivanich >CC: Arnd Bergmann >CC: "Peter Zijlstra (Intel)" >CC: Giovanni Gherdovich >CC: "Rafael J=2E Wysocki" >CC: Len Brown >CC: Kees Cook >CC: Martin Molnar >CC: Pingfan Liu >CC: linux-kernel@vger=2Ekernel=2Eorg >CC: jailhouse-dev@googlegroups=2Ecom >Signed-off-by: Andrew Cooper >--- >Thomas: I finally found the reference we were discussing in Portland=2E= =20 >Sorry >this patch took so long=2E > >I don't have any non-integrated APIC hardware to test with=2E Can anyone >help >me out? >--- > arch/x86/include/asm/x86_init=2Eh | 1 - > arch/x86/kernel/apic/x2apic_uv_x=2Ec | 1 - > arch/x86/kernel/jailhouse=2Ec | 1 - > arch/x86/kernel/platform-quirks=2Ec | 1 - > arch/x86/kernel/smpboot=2Ec | 21 ++++++++++++--------- > 5 files changed, 12 insertions(+), 13 deletions(-) > >diff --git a/arch/x86/include/asm/x86_init=2Eh >b/arch/x86/include/asm/x86_init=2Eh >index 96d9cd208610=2E=2E006a5d7fd7eb 100644 >--- a/arch/x86/include/asm/x86_init=2Eh >+++ b/arch/x86/include/asm/x86_init=2Eh >@@ -229,7 +229,6 @@ enum x86_legacy_i8042_state { > struct x86_legacy_features { > enum x86_legacy_i8042_state i8042; > int rtc; >- int warm_reset; > int no_vga; > int reserve_bios_regions; > struct x86_legacy_devices devices; >diff --git a/arch/x86/kernel/apic/x2apic_uv_x=2Ec >b/arch/x86/kernel/apic/x2apic_uv_x=2Ec >index ad53b2abc859=2E=2E5afcfd193592 100644 >--- a/arch/x86/kernel/apic/x2apic_uv_x=2Ec >+++ b/arch/x86/kernel/apic/x2apic_uv_x=2Ec >@@ -343,7 +343,6 @@ static int __init uv_acpi_madt_oem_check(char >*_oem_id, char *_oem_table_id) > } else if (!strcmp(oem_table_id, "UVH")) { > /* Only UV1 systems: */ > uv_system_type =3D UV_NON_UNIQUE_APIC; >- x86_platform=2Elegacy=2Ewarm_reset =3D 0; > __this_cpu_write(x2apic_extra_bits, pnodeid << >uvh_apicid=2Es=2Epnode_shift); > uv_set_apicid_hibit(); > uv_apic =3D 1; >diff --git a/arch/x86/kernel/jailhouse=2Ec b/arch/x86/kernel/jailhouse=2E= c >index 6eb8b50ea07e=2E=2Ed628fe92d6af 100644 >--- a/arch/x86/kernel/jailhouse=2Ec >+++ b/arch/x86/kernel/jailhouse=2Ec >@@ -210,7 +210,6 @@ static void __init jailhouse_init_platform(void) > x86_platform=2Ecalibrate_tsc =3D jailhouse_get_tsc; > x86_platform=2Eget_wallclock =3D jailhouse_get_wallclock; > x86_platform=2Elegacy=2Ertc =3D 0; >- x86_platform=2Elegacy=2Ewarm_reset =3D 0; > x86_platform=2Elegacy=2Ei8042 =3D X86_LEGACY_I8042_PLATFORM_ABSENT; >=20 > legacy_pic =3D &null_legacy_pic; >diff --git a/arch/x86/kernel/platform-quirks=2Ec >b/arch/x86/kernel/platform-quirks=2Ec >index b348a672f71d=2E=2Ed922c5e0c678 100644 >--- a/arch/x86/kernel/platform-quirks=2Ec >+++ b/arch/x86/kernel/platform-quirks=2Ec >@@ -9,7 +9,6 @@ void __init x86_early_init_platform_quirks(void) > { > x86_platform=2Elegacy=2Ei8042 =3D X86_LEGACY_I8042_EXPECTED_PRESENT; > x86_platform=2Elegacy=2Ertc =3D 1; >- x86_platform=2Elegacy=2Ewarm_reset =3D 1; > x86_platform=2Elegacy=2Ereserve_bios_regions =3D 0; > x86_platform=2Elegacy=2Edevices=2Epnpbios =3D 1; >=20 >diff --git a/arch/x86/kernel/smpboot=2Ec b/arch/x86/kernel/smpboot=2Ec >index d85e91a8aa8c=2E=2Ee2ebb0be2ee3 100644 >--- a/arch/x86/kernel/smpboot=2Ec >+++ b/arch/x86/kernel/smpboot=2Ec >@@ -1049,18 +1049,21 @@ static int do_boot_cpu(int apicid, int cpu, >struct task_struct *idle, > * the targeted processor=2E > */ >=20 >- if (x86_platform=2Elegacy=2Ewarm_reset) { >+ /* >+ * APs are typically started in one of two ways: >+ * >+ * - On 486-era hardware with a non-integrated Local APIC, a single >+ * INIT IPI is sent=2E When the AP comes out of reset, the BIOS >+ * follows the warm reset vector to start_ip=2E >+ * - On everything with an integrated Local APIC, the start_ip is >+ * provided in the Startup IPI message, sent as part of an >+ * INIT-SIPI-SIPI sequence=2E >+ */ >+ if (!APIC_INTEGRATED(boot_cpu_apic_version)) { >=20 > pr_debug("Setting warm reset code and vector=2E\n"); >=20 > smpboot_setup_warm_reset_vector(start_ip); >- /* >- * Be paranoid about clearing APIC errors=2E >- */ >- if (APIC_INTEGRATED(boot_cpu_apic_version)) { >- apic_write(APIC_ESR, 0); >- apic_read(APIC_ESR); >- } > } >=20 > /* >@@ -1118,7 +1121,7 @@ static int do_boot_cpu(int apicid, int cpu, >struct task_struct *idle, > } > } >=20 >- if (x86_platform=2Elegacy=2Ewarm_reset) { >+ if (!APIC_INTEGRATED(boot_cpu_apic_version)) { > /* > * Cleanup possible dangling ends=2E=2E=2E > */ We don't support SMP on 486 and haven't for a very long time=2E Is there a= ny reason to retain that code at all? --=20 Sent from my Android device with K-9 Mail=2E Please excuse my brevity=2E