Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp1060518imj; Thu, 14 Feb 2019 00:10:56 -0800 (PST) X-Google-Smtp-Source: AHgI3IZi1aY6Ok1cGxhgksLRJs1/e1sl6pmtqzFVinHhAbBL2lAKZPhDP7kZOvxSHKUSz+lsuZ2v X-Received: by 2002:a17:902:2966:: with SMTP id g93mr2766903plb.11.1550131856228; Thu, 14 Feb 2019 00:10:56 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550131856; cv=none; d=google.com; s=arc-20160816; b=EZPQWlluquwplLzKjld7ldNXLqnju+wYT/pXRCNIL7Licc64uPLOoPHxlrTbciCIgo 3657mfhacGyeurW4mG3mozEP+w3+SS9G/Qpv0xMlhRZxu4u99iln9OBI3vkno0chNEvy +qSO3MVhzFQ0YAF7KP1GxmxqliTZ67f8xp46hPQaCjN+6mjAnYfFAZIyPAPb5EO7Tfah WQKQpvshF90amct+2Pi6aTmrE9bMaBUREXFYoGHv1jqtrlisqqhuv9dQfJHNHSup2Ipc nuqr+b2bDI4zX3E9u3yc9ipkT5AZacVgdiUQQjzuRAVzAV5eeim16KuWqABmB9O/F4ci UP2w== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=AcCfF66RtO3K1gAF622MvdVt1WlilCyxK9jVEXcbpls=; b=ypM6tt0MdxpkK6ahfgzd3CSDikgk1akbh5ljL5dD9/a69yVXQ0vJL4FrvDNMDRIJYE +7OabqeNgp2UDVEeGpfHhRH/Vi1ILFh9JqVANMPlmLIa1OWpoqsx0SBfNQMivLBfzFZF FX48iCP+WlMpo2PFFNVW03PHr/4AXsLxhSkv84ZJtec3By1u/hP7jNyjmSytoDX2gduz +a/RNPzjq13lJOch5m3Yqbpl4OcuGtEE+dc15uslBlv5yzV67MUB0bnVvcbCtMOFQFla XiSppisgYldznFkVpHh9cIpCApww67QRwJggoFd9J77gvtQehoP294INLa6pcWoyJuAg yOIQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@wdc.com header.s=dkim.wdc.com header.b=OryP7Cio; 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=fail (p=NONE sp=NONE dis=NONE) header.from=wdc.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id t12si1765558plr.311.2019.02.14.00.10.40; Thu, 14 Feb 2019 00:10:56 -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=fail header.i=@wdc.com header.s=dkim.wdc.com header.b=OryP7Cio; 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=fail (p=NONE sp=NONE dis=NONE) header.from=wdc.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2394514AbfBMT75 (ORCPT + 99 others); Wed, 13 Feb 2019 14:59:57 -0500 Received: from esa1.hgst.iphmx.com ([68.232.141.245]:61262 "EHLO esa1.hgst.iphmx.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726333AbfBMT75 (ORCPT ); Wed, 13 Feb 2019 14:59:57 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=wdc.com; i=@wdc.com; q=dns/txt; s=dkim.wdc.com; t=1550087996; x=1581623996; h=subject:to:cc:references:from:message-id:date: mime-version:in-reply-to:content-transfer-encoding; bh=QpD3dBmdLNraB7mBIU31YrmXvC/z0J19nvCXFBllLiI=; b=OryP7CioQCJwLZ6vapr+BGhNFN6KQvJTTwaXkCHDQI5LVJX6VeZ5pVmI NEc7kdG5/0OhNi5SU0VXQzpZ1h8QYWv0PuhRpTMHsaTkLBRPi7p55lYJf RUx7ONf1N0A1bGURvVS9o5Rxp9HdVjrk2AtdDpY8RKOIq40jKssadMUbV vwfXUgN+8vEOmmR6G3fsG1iwXgE+uXnw+VLk7Ss+R5aCpasaJa2CawZfH HruDCGVWdDl/nWS2FHiobYfAnEeUCAFkUZAGN+iajYVvQizSdy99ytLbe bv+8g55D6T2D5BRR1cEv2NqLrcICfOLVtlLazFWqVytHsuwIpBlhu6nsD g==; X-IronPort-AV: E=Sophos;i="5.58,366,1544457600"; d="scan'208";a="206317894" Received: from h199-255-45-14.hgst.com (HELO uls-op-cesaep01.wdc.com) ([199.255.45.14]) by ob1.hgst.iphmx.com with ESMTP; 14 Feb 2019 03:59:56 +0800 Received: from uls-op-cesaip02.wdc.com ([10.248.3.37]) by uls-op-cesaep01.wdc.com with ESMTP; 13 Feb 2019 11:38:29 -0800 Received: from 1w4mj72.ad.shared (HELO [10.86.48.145]) ([10.86.48.145]) by uls-op-cesaip02.wdc.com with ESMTP; 13 Feb 2019 11:59:56 -0800 Subject: Re: [v4 PATCH 8/8] RISC-V: Assign hwcap as per comman capabilities. To: Johan Hovold Cc: Rob Herring , Albert Ou , Jason Cooper , Alan Kao , Dmitriy Cherkasov , Andreas Schwab , Daniel Lezcano , "linux-kernel@vger.kernel.org" , Marc Zyngier , Palmer Dabbelt , Paul Walmsley , Anup Patel , "linux-riscv@lists.infradead.org" , Thomas Gleixner References: <1549969812-22502-1-git-send-email-atish.patra@wdc.com> <1549969812-22502-9-git-send-email-atish.patra@wdc.com> <20190212112534.GB28278@localhost> <61766631-42f4-ec25-3b5c-ae892da44ccb@wdc.com> <20190213084442.GD28278@localhost> From: Atish Patra Message-ID: Date: Wed, 13 Feb 2019 11:59:55 -0800 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.13; rv:60.0) Gecko/20100101 Thunderbird/60.5.0 MIME-Version: 1.0 In-Reply-To: <20190213084442.GD28278@localhost> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2/13/19 12:44 AM, Johan Hovold wrote: > On Tue, Feb 12, 2019 at 11:58:10AM -0800, Atish Patra wrote: >> On 2/12/19 3:25 AM, Johan Hovold wrote: >>> On Tue, Feb 12, 2019 at 03:10:12AM -0800, Atish Patra wrote: >>>> Currently, we set hwcap based on first valid hart from DT. This may not >>>> be correct always as that hart might not be current booting cpu or may >>>> have a different capability. >>>> >>>> Set hwcap as the capabilities supported by all possible harts with "okay" >>>> status. >>>> >>>> Signed-off-by: Atish Patra >>>> --- >>>> arch/riscv/kernel/cpufeature.c | 41 ++++++++++++++++++++++------------------- >>>> 1 file changed, 22 insertions(+), 19 deletions(-) >>>> >>>> diff --git a/arch/riscv/kernel/cpufeature.c b/arch/riscv/kernel/cpufeature.c >>>> index e7a4701f..a1e4fb34 100644 >>>> --- a/arch/riscv/kernel/cpufeature.c >>>> +++ b/arch/riscv/kernel/cpufeature.c >>>> @@ -20,6 +20,7 @@ >>>> #include >>>> #include >>>> #include >>>> +#include >>>> >>>> unsigned long elf_hwcap __read_mostly; >>>> #ifdef CONFIG_FPU >>>> @@ -42,28 +43,30 @@ void riscv_fill_hwcap(void) >>>> >>>> elf_hwcap = 0; >>>> >>>> - /* >>>> - * We don't support running Linux on hertergenous ISA systems. For >>>> - * now, we just check the ISA of the first "okay" processor. >>>> - */ >>>> for_each_of_cpu_node(node) { >>>> - if (riscv_of_processor_hartid(node) >= 0) >>>> - break; >>>> - } >>>> - if (!node) { >>>> - pr_warn("Unable to find \"cpu\" devicetree entry\n"); >>>> - return; >>>> - } >>>> + unsigned long this_hwcap = 0; >>>> >>>> - if (of_property_read_string(node, "riscv,isa", &isa)) { >>>> - pr_warn("Unable to find \"riscv,isa\" devicetree entry\n"); >>>> - of_node_put(node); >>>> - return; >>>> - } >>>> - of_node_put(node); >>>> + if (riscv_of_processor_hartid(node) < 0) >>>> + continue; >>>> >> >>>> - for (i = 0; i < strlen(isa); ++i) >>>> - elf_hwcap |= isa2hwcap[(unsigned char)(isa[i])]; >>>> + if (of_property_read_string(node, "riscv,isa", &isa)) { >>>> + pr_warn("Unable to find \"riscv,isa\" devicetree entry\n"); >>>> + return; >>> >>> Did you want "continue" here to continue processing the other harts? >> >> Hmm. If a cpu node doesn't have isa in DT, that means DT is wrong. A >> "continue" here will let user space use other harts just with a warning >> message? >> >> Returning here will not set elf_hwcap which forces the user to fix the >> DT. I am not sure what should be the defined behavior in this case. >> >> Any thoughts ? > > The problem is that the proposed code might still set elf_hwcap -- it > all depends on the order of the hart nodes in dt (i.e. it will only be > left unset if the first node is malformed). > > For that reason, I'd say it's better to either bail out (hard or at > least with elf_hwcap unset) or to continue processing the other nodes. > > The former might break current systems with malformed dt, though. > > And since the harts are expected to have the same ISA, continuing the > processing while warning and ignoring the malformed node might be > acceptable. > ok. I will change it to continue unless somebody else has objection. Thanks for the review. Regards, Atish > Johan >