Received: by 2002:ad5:4acb:0:0:0:0:0 with SMTP id n11csp3424622imw; Mon, 11 Jul 2022 08:23:48 -0700 (PDT) X-Google-Smtp-Source: AGRyM1tAYAL9DxEGrmJuoS65AHgCGdgtEyzGr5CHk7yKH3xwVimpCgyiJdprv4K0g53U2PS9EbON X-Received: by 2002:aa7:c650:0:b0:43a:2c9a:fd1f with SMTP id z16-20020aa7c650000000b0043a2c9afd1fmr25263671edr.318.1657553027552; Mon, 11 Jul 2022 08:23:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1657553027; cv=none; d=google.com; s=arc-20160816; b=diZjvYDky/NZHqRwFDoIHTtyr/XSv/ANDWplaGIOApDLarJnBcmBJpay93aF2Ks9xh U84xcoofnmq7bgmEyZ0NCERfN7HYBPgY1xeB4CoCUfaLqTHBQ4hc23t6FICB3OD7KivM ZR2ihnMFoWwWkJkjFewPkBUi2v1ZD9nZg9IaXMMdC4HQAngr4Ix3tA3V0Dabh91ksarG pszNIxALDZ7btd/n2eqkYtb/cM1OPy2zSOMKykGM1YON7qp0AHvA4SeLT/IJUTttBlJE dvxkci89LXeFys9fPgC73hQF3VJabSxWWfsmhbwhl0uMHlZLPwYzdCMNhZBWBh4Mxt8i ndHw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=lbFu4zRZDGVnfnLBeVDiZE5w2J+AIUwIuBEc0+eRGTc=; b=MNI14NUn06gyTKmwh46/gli0X2ZSbPXkeMxY1abfLw9En7Nn+YyT8mlOK/gAXdUp4W YXX24muP2Zq/moOjk+AFE93u0cUvwqBbjU1x9Q/0F4LGtvD8qI66BUaQzrbDEymiyPyL FFFdKJfT5w1MwLKmqWDXdYOg0x4iKnW+jFn3SdSsVWtmYlvfYykaV0Ws7lpR96cZE687 ikS12V4embPretMXnRI3+ojhIc5HjVt0WkAgNr8yksfdilXEH+GP3yHnrxjD1bVd6Hiy FcU6yQy4bJK9J+9J/0BzT9NGH8XOdO0yP47Pk9uOHacJoduwujjwgu3cV3usJ8dV8HdG TFLQ== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id p34-20020a056402502200b00439b80cadb9si10476561eda.438.2022.07.11.08.23.21; Mon, 11 Jul 2022 08:23:47 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229742AbiGKPBb (ORCPT + 99 others); Mon, 11 Jul 2022 11:01:31 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56422 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232062AbiGKPBF (ORCPT ); Mon, 11 Jul 2022 11:01:05 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id BE39C5F9BA for ; Mon, 11 Jul 2022 08:00:57 -0700 (PDT) Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id BE1D91596; Mon, 11 Jul 2022 08:00:57 -0700 (PDT) Received: from bogus (unknown [10.57.39.193]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id A2DE23F70D; Mon, 11 Jul 2022 08:00:52 -0700 (PDT) Date: Mon, 11 Jul 2022 15:59:41 +0100 From: Sudeep Holla To: Conor Dooley Cc: Paul Walmsley , Palmer Dabbelt , Sudeep Holla , Palmer Dabbelt , Albert Ou , Catalin Marinas , Will Deacon , Greg Kroah-Hartman , "Rafael J . Wysocki" , Daire McNamara , Conor Dooley , Niklas Cassel , Damien Le Moal , Geert Uytterhoeven , Zong Li , Emil Renner Berthing , Jonas Hahnfeld , Guo Ren , Anup Patel , Atish Patra , Heiko Stuebner , Philipp Tomsich , Rob Herring , Marc Zyngier , Viresh Kumar , linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, Brice Goglin Subject: Re: [PATCH v3 2/2] riscv: topology: fix default topology reporting Message-ID: <20220711145941.q5rdrtavstjkp3km@bogus> References: <20220709152354.2856586-1-mail@conchuod.ie> <20220709152354.2856586-3-mail@conchuod.ie> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20220709152354.2856586-3-mail@conchuod.ie> X-Spam-Status: No, score=-6.9 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE 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 On Sat, Jul 09, 2022 at 04:23:55PM +0100, Conor Dooley wrote: > From: Conor Dooley > > RISC-V has no sane defaults to fall back on where there is no cpu-map > in the devicetree. > Without sane defaults, the package, core and thread IDs are all set to > -1. This causes user-visible inaccuracies for tools like hwloc/lstopo > which rely on the sysfs cpu topology files to detect a system's > topology. > > On a PolarFire SoC, which should have 4 harts with a thread each, > lstopo currently reports: > > Machine (793MB total) > Package L#0 > NUMANode L#0 (P#0 793MB) > Core L#0 > L1d L#0 (32KB) + L1i L#0 (32KB) + PU L#0 (P#0) > L1d L#1 (32KB) + L1i L#1 (32KB) + PU L#1 (P#1) > L1d L#2 (32KB) + L1i L#2 (32KB) + PU L#2 (P#2) > L1d L#3 (32KB) + L1i L#3 (32KB) + PU L#3 (P#3) > > Adding calls to store_cpu_topology() in {boot,smp} hart bringup code > results in the correct topolgy being reported: > > Machine (793MB total) > Package L#0 > NUMANode L#0 (P#0 793MB) > L1d L#0 (32KB) + L1i L#0 (32KB) + Core L#0 + PU L#0 (P#0) > L1d L#1 (32KB) + L1i L#1 (32KB) + Core L#1 + PU L#1 (P#1) > L1d L#2 (32KB) + L1i L#2 (32KB) + Core L#2 + PU L#2 (P#2) > L1d L#3 (32KB) + L1i L#3 (32KB) + Core L#3 + PU L#3 (P#3) > > CC: stable@vger.kernel.org > Fixes: 03f11f03dbfe ("RISC-V: Parse cpu topology during boot.") > Reported-by: Brice Goglin > Link: https://github.com/open-mpi/hwloc/issues/536 > Signed-off-by: Conor Dooley > --- > --- > arch/riscv/Kconfig | 2 +- > arch/riscv/kernel/smpboot.c | 4 +++- > 2 files changed, 4 insertions(+), 2 deletions(-) > > diff --git a/arch/riscv/Kconfig b/arch/riscv/Kconfig > index 2af0701b7518..4b6c2fdbb57c 100644 > --- a/arch/riscv/Kconfig > +++ b/arch/riscv/Kconfig > @@ -52,7 +52,7 @@ config RISCV > select COMMON_CLK > select CPU_PM if CPU_IDLE > select EDAC_SUPPORT > - select GENERIC_ARCH_TOPOLOGY if SMP > + select GENERIC_ARCH_TOPOLOGY I am not sure of !SMP as ARM64 is default SMP only. I have never reviewed the arch topology code with !SMP considered. I will leave that part to RISC-V developers. > select GENERIC_ATOMIC64 if !64BIT > select GENERIC_CLOCKEVENTS_BROADCAST if SMP > select GENERIC_EARLY_IOREMAP > diff --git a/arch/riscv/kernel/smpboot.c b/arch/riscv/kernel/smpboot.c > index f1e4948a4b52..a1c861f84fe2 100644 > --- a/arch/riscv/kernel/smpboot.c > +++ b/arch/riscv/kernel/smpboot.c > @@ -40,6 +40,8 @@ static DECLARE_COMPLETION(cpu_running); > void __init smp_prepare_boot_cpu(void) > { > init_cpu_topology(); > + > + store_cpu_topology(smp_processor_id()); > } > > void __init smp_prepare_cpus(unsigned int max_cpus) > @@ -161,9 +163,9 @@ asmlinkage __visible void smp_callin(void) > mmgrab(mm); > current->active_mm = mm; > > + store_cpu_topology(curr_cpuid); > notify_cpu_starting(curr_cpuid); > numa_add_cpu(curr_cpuid); > - update_siblings_masks(curr_cpuid); > set_cpu_online(curr_cpuid, 1); > > /* Other than that, this looks good. FWIW: Reviewed-by: Sudeep Holla -- Regards, Sudeep