Received: by 2002:a05:6358:c692:b0:131:369:b2a3 with SMTP id fe18csp5507676rwb; Tue, 1 Aug 2023 03:56:35 -0700 (PDT) X-Google-Smtp-Source: APBJJlE1Li5dUzcMsjBCsM5pbesGJ4wvly84zqNCnLzqN05BXGypD+b8+H1q1sc37tA5UnvjE1HX X-Received: by 2002:a17:907:2be2:b0:974:771e:6bf0 with SMTP id gv34-20020a1709072be200b00974771e6bf0mr1988658ejc.56.1690887395434; Tue, 01 Aug 2023 03:56:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1690887395; cv=none; d=google.com; s=arc-20160816; b=mre6v4cl1pp19bT0kf+Tjjgzz5PFSnJrvTYkEZtFs80SnPQLNVO7kxlgnJv+I1MOIH tZVqtrIL7Hdo8eJj82CPITF1wzZFHw9NpqkNrs9cgZZlv2wPMUKqzUvJWC8RhuxXBkTq SFkMWM4+d4a5qMzq6KGcEnwkdWloCViBjD921DGoiNKSCNl+Qkx55t7ONbHJb3d95MB8 DQnhEpODSlG3waFMVPzs/S4XlnxsGr767Ia4gHW1LV6LeTdJGLjKDqz0ae8weiUrpZ/v 4ourmprivISPa2yBqPvDqyNlzyHbti86k56SqzMslBwZLnrPPHscSvXZ0i8CcwEs1fgj huoQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:date:subject:cc:to:from:dkim-signature :dkim-signature:message-id; bh=gddeRoPs5mtWh3jrpXwXoH25By/eZKLOXLpdHngWqR0=; fh=wMSvDXu8aIctG0BkLX/h/O+j330BBHOD6MPYFjhkfeU=; b=qh+Yw74SaFIB4KO3tQxvMLmuH7O3+o+IWiVPkNQFporVioJJ2S7fzdw+jk29icBfa/ HgVIO6HHOK167LqbWwHSUPHtb+fXNRKq0IOhAO5sBP93sHobnTrpRwiOTQrtUbDiwoy5 gNjK0A9Pr09dIqIdyV8LSBj0V59gSRWx+bdssapmFUnArnTPYEWrJmFwUsJXpuqwJgcD fZUyjzNs4KXzcD7rK/4TOfAV00MCrZYN0rSTMRUYv9PUyVKM56BheOAn5f9YPII0pEzy AM1D5+hPqEVXTA0AviYg+Hvo+AD/kgt59roaqEkZE3wmbUa27eI7onQsnBHvAx8lV2P6 PSjg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=I1dTGQAi; dkim=neutral (no key) header.i=@linutronix.de; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id x23-20020a1709065ad700b0098b0feb8935si5525029ejs.1035.2023.08.01.03.56.11; Tue, 01 Aug 2023 03:56:35 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=I1dTGQAi; dkim=neutral (no key) header.i=@linutronix.de; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=linutronix.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232155AbjHAKqp (ORCPT + 99 others); Tue, 1 Aug 2023 06:46:45 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56568 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231285AbjHAKqo (ORCPT ); Tue, 1 Aug 2023 06:46:44 -0400 Received: from galois.linutronix.de (Galois.linutronix.de [IPv6:2a0a:51c0:0:12e:550::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D2F08E9 for ; Tue, 1 Aug 2023 03:46:43 -0700 (PDT) Message-ID: <20230801103042.936020332@linutronix.de> DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1690886801; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc; bh=gddeRoPs5mtWh3jrpXwXoH25By/eZKLOXLpdHngWqR0=; b=I1dTGQAirB5sJR3ctSAkVS9Oh+mvQFxVYJ7rWzu3UtqI2P4IchZWhj9m9zrVQCcqU5qiKE ZJ/oFNr248bBs10UGv4n+a4nIxfSHjAvs4cFDTNmVDlsbJYB/pkor+2Q2A8duFG69tUUZZ Jw/R0FH+9kI74gM0ZnIRkhD8OUlvJoPPwp5H84juT5zhtH/RcbsgOYpcnh8/0kiywBqnfj rnR2XIyR47Fgx0zW/sdG9e4IBXzFtJMAeoHBKQt4LqthjSCRA8hknmkWFgRF3DfkJvYbOJ mPyUwVjEMTHQKUk6pbethfBdvXRLmvHkhadmO6MLPoqfSnPXC0awjia2m87tuA== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1690886801; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc; bh=gddeRoPs5mtWh3jrpXwXoH25By/eZKLOXLpdHngWqR0=; b=q6eh3XeA/G4+3zXgklBxQMDXUJanqiYCYHYxZ4gNsXBDLiovFedgiUz3BaUIgKlCBzC16n hhpztFYheqoJABCg== From: Thomas Gleixner To: LKML Cc: x86@kernel.org, Andrew Cooper , Tom Lendacky , Paolo Bonzini , Wei Liu , Arjan van de Ven , Juergen Gross , Michael Kelley , Peter Keresztes Schmidt Subject: [patch V3 00/60] x86/apic: Decrapification and static calls Date: Tue, 1 Aug 2023 12:46:41 +0200 (CEST) X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi! This is the follow up to: https://lore.kernel.org/lkml/20230724131206.500814398@linutronix.de which addresses the XEN PV fallout decoded by Juergen. TLDR: This cleans up accrued and partially unused gunk in order to convert the APIC callbacks to static calls. The changes vs. V2: - Unbreak XEN/PV - Juergen Resulting delta patch below. - Rebased to 6.5-rc4 in preparation for the CPUID overhaul on top, which has some collisions due to the recent mitigation muck. The series is also available from git: git://git.kernel.org/pub/scm/linux/kernel/git/tglx/devel.git apic-static-call-v3 Thanks, tglx --- diff --git a/arch/x86/xen/apic.c b/arch/x86/xen/apic.c index 468406f511ff..7ad91225fdf4 100644 --- a/arch/x86/xen/apic.c +++ b/arch/x86/xen/apic.c @@ -155,20 +155,9 @@ static struct apic xen_pv_apic __ro_after_init = { .icr_read = xen_apic_icr_read, .icr_write = xen_apic_icr_write, }; - -static void __init xen_apic_check(void) -{ - apic_install_driver(&xen_pv_apic); -} +apic_driver(xen_pv_apic); void __init xen_init_apic(void) { x86_apic_ops.io_apic_read = xen_io_apic_read; - /* On PV guests the APIC CPUID bit is disabled so none of the - * routines end up executing. */ - if (!xen_initial_domain()) - apic_install_driver(&xen_pv_apic); - - x86_platform.apic_post_init = xen_apic_check; } -apic_driver(xen_pv_apic); diff --git a/arch/x86/xen/enlighten_pv.c b/arch/x86/xen/enlighten_pv.c index 93b658248d01..c393c44892ac 100644 --- a/arch/x86/xen/enlighten_pv.c +++ b/arch/x86/xen/enlighten_pv.c @@ -1326,7 +1326,7 @@ asmlinkage __visible void __init xen_start_kernel(struct start_info *si) x86_init.resources.memory_setup = xen_memory_setup; x86_init.irqs.intr_mode_select = x86_init_noop; - x86_init.irqs.intr_mode_init = x86_init_noop; + x86_init.irqs.intr_mode_init = x86_64_probe_apic; x86_init.oem.arch_setup = xen_arch_setup; x86_init.oem.banner = xen_banner; x86_init.hyper.init_platform = xen_pv_init_platform; @@ -1366,12 +1366,10 @@ asmlinkage __visible void __init xen_start_kernel(struct start_info *si) xen_init_capabilities(); -#ifdef CONFIG_X86_LOCAL_APIC /* * set up the basic apic ops. */ xen_init_apic(); -#endif machine_ops = xen_machine_ops; diff --git a/arch/x86/xen/smp_pv.c b/arch/x86/xen/smp_pv.c index c6b42c66c60c..a0f07bbfcd6e 100644 --- a/arch/x86/xen/smp_pv.c +++ b/arch/x86/xen/smp_pv.c @@ -182,7 +182,8 @@ static void __init _get_smp_config(unsigned int early) if (subtract) set_nr_cpu_ids(nr_cpu_ids - subtract); #endif - + /* Pretend to be a proper enumerated system */ + smp_found_config = 1; } static void __init xen_pv_smp_prepare_boot_cpu(void)