Received: by 2002:a05:7412:31a9:b0:e2:908c:2ebd with SMTP id et41csp3835594rdb; Thu, 14 Sep 2023 04:22:28 -0700 (PDT) X-Google-Smtp-Source: AGHT+IEUecOz6bqXdJMhgrDffy0Qe1/nnvbadnDVOhg/gzmT6YksOTT0OemVKqu3ItwZhrkmMwT3 X-Received: by 2002:a17:902:788a:b0:1bb:6875:5a73 with SMTP id q10-20020a170902788a00b001bb68755a73mr4966468pll.2.1694690547739; Thu, 14 Sep 2023 04:22:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1694690547; cv=none; d=google.com; s=arc-20160816; b=iaDgH8Un9cGuwB3j/++xyGA8VYdHr99SJChUWu7AUfGd+7wI0dPQ582xzfcglm/vA2 cAJsekbpI8q6ej6G+BVviU3n6eyAUdynl4X5SFMVfMCs1+yawVryZ81O58chucG/99X+ fTHtn9sZhaN0x3gzBQFj1jdE+hHsKyiFbJTTRNKS+0dG+RC8TObwiVCUIMV0h0S3hhKy R8CfGK0Son4wOtePZkYqDYprtOgAq30J3nxklcrearZ7D+uRCY84pvl0T2mJCbee5LtT 5qOpi+oUOJGEtymIEOhUtcQGbDvbAvMfZ1hbv92jVsNTrsjGHk2868VJXm7iPy/6SZgZ p4WQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=mJIualwweUZGp55FBJbOqzxQCkNxNmUE1MPBTrTAheg=; fh=pMMXRxvWGXnCYrOd/QiVGHprxE+V02PkCqS+pzvn+p8=; b=OvzR5mJ9c+WU7R2oMR/ERxzgBI0qmoHxfBWwlw8pkhz558RX8w68RnIBU6zta3hV1l rRk3IUFDcb5P4uwOsza65ruif5aE0Ln3WUpwx7Oj2+MHuZZ7GU4vwC5hq2HFU09u48E8 0Eyz7zkpmETiXk67NHE7TtGBZ1nABv6JGLrZRF9ZHxBrHZUyFfoncCmYGID6KBWNioru bxBHt8KwW9mABgOkJ/AumA26IaH0KCoNOEOtJViW+exHkC0DwM4LKSam+Tcw6do//0Kc 6CO1BIvaxdlzHh51p5o2HqqvBXWV8aNFUFoalOuqBzZFb8vev+s5aVg1QkhVAMSAB/bd j7UQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail (test mode) header.i=@armlinux.org.uk header.s=pandora-2019 header.b=lQUPBh86; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:8 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=armlinux.org.uk Return-Path: Received: from fry.vger.email (fry.vger.email. [2620:137:e000::3:8]) by mx.google.com with ESMTPS id v13-20020a170903238d00b001bba90f8b73si1419087plh.78.2023.09.14.04.22.27 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 14 Sep 2023 04:22:27 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:8 as permitted sender) client-ip=2620:137:e000::3:8; Authentication-Results: mx.google.com; dkim=fail (test mode) header.i=@armlinux.org.uk header.s=pandora-2019 header.b=lQUPBh86; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:8 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=armlinux.org.uk Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by fry.vger.email (Postfix) with ESMTP id 482B6807516A; Thu, 14 Sep 2023 04:11:18 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at fry.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232706AbjINLLN (ORCPT + 99 others); Thu, 14 Sep 2023 07:11:13 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60830 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229458AbjINLLM (ORCPT ); Thu, 14 Sep 2023 07:11:12 -0400 Received: from pandora.armlinux.org.uk (pandora.armlinux.org.uk [IPv6:2001:4d48:ad52:32c8:5054:ff:fe00:142]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 59CA410E6; Thu, 14 Sep 2023 04:11:07 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=armlinux.org.uk; s=pandora-2019; h=Sender:In-Reply-To:Content-Type: MIME-Version:References:Message-ID:Subject:Cc:To:From:Date:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=mJIualwweUZGp55FBJbOqzxQCkNxNmUE1MPBTrTAheg=; b=lQUPBh86IwhBsrufNHvbGJoswo o9WAIvldkMVcmqVtmLe5/6bLSewxs+Z2zKOFUciTaBwoznYr/4l9q1BrCNdgMNpyyPJ/FQAJQqRpt HHPuTWXi9FGJI4Fsakq2zuSMCKpyqM9oWOuYFQg3YEY87mcZjBbVyzCG8PlrEOJO4eUs3JYcUsNSV 8M1bStdBbGXRz//qXyqilYXz8P/SR3qc6qUFRIBYgyqe6k/ZgeXQE3yBRrtC1g7RGzGLmqTUy/SDw /fKly5ax5mvdKXPRIs0p+eZHMMcY7PYLdgGANRVsDAltijZWEvJAGZoJa9kIJdA5fKcBYM17kUQa+ XM7+8THQ==; Received: from shell.armlinux.org.uk ([fd8f:7570:feb6:1:5054:ff:fe00:4ec]:55622) by pandora.armlinux.org.uk with esmtpsa (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.96) (envelope-from ) id 1qgkFT-0003wU-1z; Thu, 14 Sep 2023 12:11:03 +0100 Received: from linux by shell.armlinux.org.uk with local (Exim 4.94.2) (envelope-from ) id 1qgkFT-0004iX-Gc; Thu, 14 Sep 2023 12:11:03 +0100 Date: Thu, 14 Sep 2023 12:11:03 +0100 From: "Russell King (Oracle)" To: Jonathan Cameron Cc: James Morse , linux-pm@vger.kernel.org, loongarch@lists.linux.dev, linux-acpi@vger.kernel.org, linux-arch@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-riscv@lists.infradead.org, kvmarm@lists.linux.dev, x86@kernel.org, Salil Mehta , Jean-Philippe Brucker , jianyong.wu@arm.com, justin.he@arm.com Subject: Re: [RFC PATCH v2 02/35] drivers: base: Use present CPUs in GENERIC_CPU_DEVICES Message-ID: References: <20230913163823.7880-1-james.morse@arm.com> <20230913163823.7880-3-james.morse@arm.com> <20230914115613.0000778e@Huawei.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20230914115613.0000778e@Huawei.com> Sender: Russell King (Oracle) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (fry.vger.email [0.0.0.0]); Thu, 14 Sep 2023 04:11:18 -0700 (PDT) X-Spam-Status: No, score=-0.6 required=5.0 tests=DKIM_INVALID,DKIM_SIGNED, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,SPF_HELO_NONE, SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on fry.vger.email On Thu, Sep 14, 2023 at 11:56:13AM +0100, Jonathan Cameron wrote: > On Thu, 14 Sep 2023 09:20:54 +0100 > "Russell King (Oracle)" wrote: > > > On Wed, Sep 13, 2023 at 04:37:50PM +0000, James Morse wrote: > > > Three of the five ACPI architectures create sysfs entries using > > > register_cpu() for present CPUs, whereas arm64, riscv and all > > > GENERIC_CPU_DEVICES do this for possible CPUs. > > > > > > Registering a CPU is what causes them to show up in sysfs. > > > > > > It makes very little sense to register all possible CPUs. Registering > > > a CPU is what triggers the udev notifications allowing user-space to > > > react to newly added CPUs. > > > > > > To allow all five ACPI architectures to use GENERIC_CPU_DEVICES, change > > > it to use for_each_present_cpu(). Making the ACPI architectures use > > > GENERIC_CPU_DEVICES is a pre-requisite step to centralise their > > > cpu_register() logic, before moving it into the ACPI processor driver. > > > When ACPI is disabled this work would be done by > > > cpu_dev_register_generic(). > > > > > > Of the ACPI architectures that register possible CPUs, arm64 and riscv > > > do not support making possible CPUs present as they use the weak 'always > > > fails' version of arch_register_cpu(). > > > > > > Only two of the eight architectures that use GENERIC_CPU_DEVICES have a > > > distinction between present and possible CPUs. > > > > > > The following architectures use GENERIC_CPU_DEVICES but are not SMP, > > > so possible == present: > > > * m68k > > > * microblaze > > > * nios2 > > > > > > The following architectures use GENERIC_CPU_DEVICES and consider > > > possible == present: > > > * csky: setup_smp() > > > * parisc: smp_prepare_boot_cpu() marks the boot cpu as present, > > > processor_probe() sets possible for all CPUs and present for all CPUs > > > except the boot cpu. > > > > However, init/main.c::start_kernel() calls boot_cpu_init() which sets > > the boot CPU in the online, active, present and possible masks. So, > > _every_ architecture gets the boot CPU in all these masks no matter > > what. > > > > Only of something then clears the boot CPU from these masks (which > > would be silly) would the boot CPU not be in all of these masks. > Hi Russel, > > Upshot is that the code in parisc smp_prepare_boot_cpu() can be dropped? > Seems like another useful simplification to add to front of this series. Yes - but I personally (and probably others) would like to see progress made towards getting at least some of the changes in this series merged, rather than seeing this series hang around longer and grow. Nothing in this series touches any architecture's smp_prepare_boot_cpu(), so such a change would not interfere with this series. Therefore, I suggest that removing those two set_cpu_*() calls in smp_prepare_boot_cpu() is something that could happen irrespective of anything in this series, and I would encourage PA-RISC folk to do that anway. The same is true of Loongarch, mips, sh, and sparc32, and they can independently sort this. > Seems there are lots of other empty implementations of smp_prepare_boot_cpu() > maybe worth making that optional whilst here and dropping all the empty ones? Yes, and again, this could be a series separate from this one. If one arch wants to add the empty weak version of smp_prepare_boot_cpu(), then it would be a matter of others deleting their empty implementation (possibly after first having cleaned up the unnecessary set_cpu_*() calls). In any case, I would expect that patches doing any of the above would end up being cherry-picked from a series by arch maintainers, so at least to me it makes zero sense to include it with this already large series, and would make the management of this series more complex. -- RMK's Patch system: https://www.armlinux.org.uk/developer/patches/ FTTP is here! 80Mbps down 10Mbps up. Decent connectivity at last!