Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp5101305imu; Tue, 8 Jan 2019 11:31:10 -0800 (PST) X-Google-Smtp-Source: ALg8bN5AcoKUcd60BZW6wS2lU+lkkcSZR/Vg0TZQb1z85D2kasIf1xiXbnCNJ1oHx6Wv2aEum3OW X-Received: by 2002:a62:11c7:: with SMTP id 68mr2974581pfr.21.1546975870851; Tue, 08 Jan 2019 11:31:10 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1546975870; cv=none; d=google.com; s=arc-20160816; b=FyY4Wyqe12jyKkrlTzyfRM2nRszT04DI2pc9XpwACsUXI8BoZeOxlsvFiVOo3KWrGH L/GEkLtzRvKdUWAgNH4hOFntQI4FjNeHHItnMvIX+a0PrUZXkvr846NgwkvRo6/Qus0S rzxQuc3x2wOURiUOwINZfkDz+02Y7mWZaeej9p3AntoONCQvpFgPQBjBhVj+9Q4o1ouW r/p7XLaSgQEUFtwWNxLtz6/QyqohzuD8WOF0mFrqRwPRzOA/QSPeXhOqKPc76UcqbIHP 92FhxRKM/o04UXR9m6oTfdnHBAOcBeKX4x/6YxQ43ALp+kaJZloIkjoP6JpSPnxHX/aI 0I0w== 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:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=EceepDLU2zPQV67lOUTwy5E6SU3GuQpwmbFa6tS0BiI=; b=rDGn/yvFfR3jqx4nTlWiqBX9eW0tS9DxJTHSVfoxq1wGjwGFkGBEoHU0rJ84DuXj50 6hYLaUj2gt1zVoAaGE8MxVEboO96qS/ltNfVrxlDfRKTI3GhdUC+8hDwqT221lOZPp3E wrhCc0Is+O+7jqZMRpgID1jAfuYl//9cDaN/7RnMC/UBVEPusLFeRHBKevTiP8VYGeUR NjOhLNkOJEbte2fSJFcmgTlrSxnDkug5e17vTshgwTxmt0bBuAsjOe6hfOrPAniHwX+k +G0DD9MCsrzetshhmHTqN2pESefiQqCvK0wgAyCx6WTkO4Ih+SpvjkM702xh+NC8dv5O BqEw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=KzKychG4; 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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w7si28567047ply.421.2019.01.08.11.30.55; Tue, 08 Jan 2019 11:31:10 -0800 (PST) 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=pass header.i=@kernel.org header.s=default header.b=KzKychG4; 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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729613AbfAHT3H (ORCPT + 99 others); Tue, 8 Jan 2019 14:29:07 -0500 Received: from mail.kernel.org ([198.145.29.99]:36200 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729559AbfAHT3B (ORCPT ); Tue, 8 Jan 2019 14:29:01 -0500 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 6CF5720645; Tue, 8 Jan 2019 19:28:59 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1546975740; bh=KJyv+xTTUzWQsjlwwYCag+ywrGXmxS055XSsJnc8NNE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=KzKychG4klYrjHb7jI/gV8H3mB+XOz+YehCc38xM+X/wbTtYi05QU726H8EU7Rec5 BLWo+nepL4Tjx4PnhSOBqu94s/VT1qMINuxeR+rZGZkteuSwThmL9x36CPpmqG7b1i YBmaqgBkP0vg1/6t8MyOGed6/5BS/vKUo3eytATU= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Hui Wang , Thomas Gleixner , guijianfeng@huawei.com, wencongyang2@huawei.com, douliyang1@huawei.com, qiaonuohan@huawei.com, Sasha Levin Subject: [PATCH AUTOSEL 4.20 087/117] x86/topology: Use total_cpus for max logical packages calculation Date: Tue, 8 Jan 2019 14:25:55 -0500 Message-Id: <20190108192628.121270-87-sashal@kernel.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20190108192628.121270-1-sashal@kernel.org> References: <20190108192628.121270-1-sashal@kernel.org> MIME-Version: 1.0 X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Hui Wang [ Upstream commit aa02ef099cff042c2a9109782ec2bf1bffc955d4 ] nr_cpu_ids can be limited on the command line via nr_cpus=. This can break the logical package management because it results in a smaller number of packages while in kdump kernel. Check below case: There is a two sockets system, each socket has 8 cores, which has 16 logical cpus while HT was turn on. 0 1 2 3 4 5 6 7 | 16 17 18 19 20 21 22 23 cores on socket 0 threads on socket 0 8 9 10 11 12 13 14 15 | 24 25 26 27 28 29 30 31 cores on socket 1 threads on socket 1 While starting the kdump kernel with command line option nr_cpus=16 panic was triggered on one of the cpus 24-31 eg. 26, then online cpu will be 1-15, 26(cpu 0 was disabled in kdump), ncpus will be 16 and __max_logical_packages will be 1, but actually two packages were booted on. This issue can reproduced by set kdump option nr_cpus=, and then trigger panic on last socket's thread, for example: taskset -c 26 echo c > /proc/sysrq-trigger Use total_cpus which will not be limited by nr_cpus command line to calculate the value of __max_logical_packages. Signed-off-by: Hui Wang Signed-off-by: Thomas Gleixner Cc: Cc: Cc: Cc: Link: https://lkml.kernel.org/r/20181107023643.22174-1-john.wanghui@huawei.com Signed-off-by: Sasha Levin --- arch/x86/kernel/smpboot.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/arch/x86/kernel/smpboot.c b/arch/x86/kernel/smpboot.c index a9134d1910b9..ccd1f2a8e557 100644 --- a/arch/x86/kernel/smpboot.c +++ b/arch/x86/kernel/smpboot.c @@ -1347,7 +1347,7 @@ void __init calculate_max_logical_packages(void) * extrapolate the boot cpu's data to all packages. */ ncpus = cpu_data(0).booted_cores * topology_max_smt_threads(); - __max_logical_packages = DIV_ROUND_UP(nr_cpu_ids, ncpus); + __max_logical_packages = DIV_ROUND_UP(total_cpus, ncpus); pr_info("Max logical packages: %u\n", __max_logical_packages); } -- 2.19.1