Received: by 2002:ab2:3c46:0:b0:1f5:f2ab:c469 with SMTP id x6csp292485lqf; Fri, 26 Apr 2024 07:02:47 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCXcCV/Wckd2iwMpLDXzbsayWPGEzHJnu+hg/i3bx3BIAZHRVrsexsXjh2tpTjfXCTy8uqIqDUiGxrtCynxQbMemclzG8XHuqusHnEdx3g== X-Google-Smtp-Source: AGHT+IFgBCcVQhVZ4zWRHlMLWKlAokp8zXNU1VfpkaUXwwX/Rq6z63soVNE56YnVQMpPJrC3uUZK X-Received: by 2002:a17:902:e5d1:b0:1e0:c3b5:196 with SMTP id u17-20020a170902e5d100b001e0c3b50196mr10164461plf.20.1714140166813; Fri, 26 Apr 2024 07:02:46 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1714140166; cv=pass; d=google.com; s=arc-20160816; b=z5xFMitcHCgpQv8u420VyQSTrnpXGFB0wjk3VR3W4gPD7iq96mpt/7cZWnDcESglu6 ZZGd7Vty0sWZ4meV5+5hvXs4mCTFoaKIZW2As8jB/Y7kKlAu2iKA+wuLa23bixv4XzcJ 1V+VnBM1m1YIMcukk/qcDhe40YEbvW9p2yb6uJ3ub6TztScX30rD/lpxU+KRBWYKwtM3 xlnF7clYL7tmTiUwMKM1EI0jJc5waVX6FPoOivh1NBeEOq0RWsoXT45lQE/T7uO75ws6 8B0m53c7lOzcdbmovVV3VhAyITS8AmVyZmgN+TLj02uQouLhp6xggr1pu4UEzQpv9Ifw qorw== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from; bh=QUJ4i5zDy12wpUA6y4XrPKlxK2nsLVUhEL5Y2zPP3io=; fh=QfGN+Nlycv3VEqD8X65neWxvyXXboUCZUO7iSMK6eUk=; b=N0179hYDCMPLG7+RwbviUbZz8D7Q2QluODNJpfY8KRQOjl0d7bPKXAKbRlhp4MW3hd 8lDW3LZF32gTGOTCd85AmdFBsNyE/DwI1qAcAmqfgS+IFaifFygynRrwFEhtoNc5Gs5K wuSnIB2L3a3aSMm0BDEcyAjpmcc6iwV1kh/NhSidb6oywgLGUHjIBE48xkKqJ0BsnG1P ahNroEvZSOnPz1xPMYiNykcRAkqnL9+NlC5YBHqqzQcUlXWGEV89f7FjcEk/Tw4xTzWR LKJ6sTw61ezxBP9uqb7V9hWmkwG/7Ltlk+p6CE9ouInzL/7MCQlfQVP4HWQ0faTpbmaY OZYg==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; arc=pass (i=1 spf=pass spfdomain=huawei.com dmarc=pass fromdomain=huawei.com); spf=pass (google.com: domain of linux-kernel+bounces-160104-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-160104-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from sy.mirrors.kernel.org (sy.mirrors.kernel.org. [147.75.48.161]) by mx.google.com with ESMTPS id z6-20020a656646000000b006060744c5e8si4995160pgv.317.2024.04.26.07.02.46 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 26 Apr 2024 07:02:46 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-160104-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) client-ip=147.75.48.161; Authentication-Results: mx.google.com; arc=pass (i=1 spf=pass spfdomain=huawei.com dmarc=pass fromdomain=huawei.com); spf=pass (google.com: domain of linux-kernel+bounces-160104-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.48.161 as permitted sender) smtp.mailfrom="linux-kernel+bounces-160104-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sy.mirrors.kernel.org (Postfix) with ESMTPS id 0F097B2331E for ; Fri, 26 Apr 2024 13:56:47 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id D6319148826; Fri, 26 Apr 2024 13:54:35 +0000 (UTC) Received: from frasgout.his.huawei.com (frasgout.his.huawei.com [185.176.79.56]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 38CE71487C3; Fri, 26 Apr 2024 13:54:33 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=185.176.79.56 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1714139675; cv=none; b=UDS39MtczJT35/GVaPRSKoUGSMThmFG7CEJBGSqJz1DHaxHPFTVWGyrX+Yaqb93Y/31wy7i533NVa850/A9rF3wDifpiQro0s24/wGCEJLAGSOpDlQkhij3Gsx5CUypBWFNVdtqIKbrSwTgf8nETL5xu4FzXmn2ghVFM9aAqiIg= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1714139675; c=relaxed/simple; bh=XzlBEvzmaHxv8L38RsHV7BNKS/eL1vkrGnnq6JM9ZAA=; h=From:To:CC:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version:Content-Type; b=Ad6k7jJBBHz4Kp9jRo/Zk1yvYCuk3/Dx2e3j9RmbqlBHcklapxzq48kVjNKLLcim99ID4e8VsdCv62C4FWYBd4ovuLhuMUdcjTYxPpqO78U6l10ZBEZ9Kyhv2b31sOxEozJxIqaAjjdDVJVhjBRCP4pfLXAWk9jjNQMvi9PzS1Q= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=huawei.com; spf=pass smtp.mailfrom=huawei.com; arc=none smtp.client-ip=185.176.79.56 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=huawei.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=huawei.com Received: from mail.maildlp.com (unknown [172.18.186.31]) by frasgout.his.huawei.com (SkyGuard) with ESMTP id 4VQvNC2wp6z6DBBW; Fri, 26 Apr 2024 21:54:19 +0800 (CST) Received: from lhrpeml500005.china.huawei.com (unknown [7.191.163.240]) by mail.maildlp.com (Postfix) with ESMTPS id 0903F140A87; Fri, 26 Apr 2024 21:54:31 +0800 (CST) Received: from SecurePC-101-06.china.huawei.com (10.122.247.231) by lhrpeml500005.china.huawei.com (7.191.163.240) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.1.2507.35; Fri, 26 Apr 2024 14:54:30 +0100 From: Jonathan Cameron To: Thomas Gleixner , Peter Zijlstra , , , , , , , , , Russell King , "Rafael J . Wysocki" , Miguel Luis , James Morse , Salil Mehta , Jean-Philippe Brucker , Catalin Marinas , Will Deacon , Marc Zyngier , Hanjun Guo CC: Ingo Molnar , Borislav Petkov , Dave Hansen , , , , Lorenzo Pieralisi , Sudeep Holla Subject: [PATCH v8 06/16] ACPI: processor: Register deferred CPUs from acpi_processor_get_info() Date: Fri, 26 Apr 2024 14:51:16 +0100 Message-ID: <20240426135126.12802-7-Jonathan.Cameron@huawei.com> X-Mailer: git-send-email 2.39.2 In-Reply-To: <20240426135126.12802-1-Jonathan.Cameron@huawei.com> References: <20240426135126.12802-1-Jonathan.Cameron@huawei.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-ClientProxiedBy: lhrpeml500002.china.huawei.com (7.191.160.78) To lhrpeml500005.china.huawei.com (7.191.163.240) From: James Morse The arm64 specific arch_register_cpu() call may defer CPU registration until the ACPI interpreter is available and the _STA method can be evaluated. If this occurs, then a second attempt is made in acpi_processor_get_info(). Note that the arm64 specific call has not yet been added so for now this will be called for the original hotplug case. For architectures that do not defer until the ACPI Processor driver loads (e.g. x86), for initially present CPUs there will already be a CPU device. If present do not try to register again. Systems can still be booted with 'acpi=off', or not include an ACPI description at all as in these cases arch_register_cpu() will not have deferred registration when first called. This moves the CPU register logic back to a subsys_initcall(), while the memory nodes will have been registered earlier. Note this is where the call was prior to the cleanup series so there should be no side effects of moving it back again for this specific case. [PATCH 00/21] Initial cleanups for vCPU HP. https://lore.kernel.org/all/ZVyz%2FVe5pPu8AWoA@shell.armlinux.org.uk/ commit 5b95f94c3b9f ("x86/topology: Switch over to GENERIC_CPU_DEVICES") Signed-off-by: James Morse Reviewed-by: Gavin Shan Tested-by: Miguel Luis Tested-by: Vishnu Pajjuri Tested-by: Jianyong Wu Signed-off-by: Russell King (Oracle) Co-developed-by: Jonathan Cameron Signed-off-by: Jonathan Cameron Reviewed-by: Hanjun Guo Acked-by: Rafael J. Wysocki --- v8: Fxed spelling of my own name... (tags picked up) --- drivers/acpi/acpi_processor.c | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/drivers/acpi/acpi_processor.c b/drivers/acpi/acpi_processor.c index ecc2721fecae..88108aecbcfa 100644 --- a/drivers/acpi/acpi_processor.c +++ b/drivers/acpi/acpi_processor.c @@ -357,14 +357,14 @@ static int acpi_processor_get_info(struct acpi_device *device) } /* - * Extra Processor objects may be enumerated on MP systems with - * less than the max # of CPUs. They should be ignored _iff - * they are physically not present. - * - * NOTE: Even if the processor has a cpuid, it may not be present - * because cpuid <-> apicid mapping is persistent now. + * This code is not called unless we know the CPU is present and + * enabled. The two paths are: + * a) Initially present CPUs on architectures that do not defer + * their arch_register_cpu() calls until this point. + * b) Hotplugged CPUs (enabled bit in _STA has transitioned from not + * enabled to enabled) */ - if (invalid_logical_cpuid(pr->id) || !cpu_present(pr->id)) { + if (!get_cpu_device(pr->id)) { int ret = acpi_processor_hotadd_init(pr, device); if (ret) -- 2.39.2