Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp1785160imm; Thu, 16 Aug 2018 02:33:43 -0700 (PDT) X-Google-Smtp-Source: AA+uWPwmf4nV5f8BgMNri2quiDcYGXvXaegTGLuYXM5QjeehLr3FW/p3iNk7/0mSauBMPE4dQscN X-Received: by 2002:a17:902:6b47:: with SMTP id g7-v6mr28350680plt.128.1534412023635; Thu, 16 Aug 2018 02:33:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1534412023; cv=none; d=google.com; s=arc-20160816; b=LOIMGoz9vq7zFHUUdWdFERM0l3WzwYL8y5t1PlDKtJ+ZpNMT6ebZ5xGJpZHQQzBbnY sQz3cGQ/EPVQlWa1t+v5H/cHjD0vpALN5G30zhv18wTscVRNPGc+Eo8BVFXQnGkAVy5d HJQkwgaiGl4JZWy8Ad990FQUh0gHpMHsAHdjIud1nGN0N5PaUt0iPAlLdJ/147mWDH6E ztrCOasSsYHQXrecGtdW83jEmkb+j/Y7hj+XDpOEctmFy57vGpkxAvyXZkmoFUrJ7yxs szzURMaCMzjGSNCKOJbhmEofapuhaNEG1Cnhtqsk6wJBoRBqcYE8/RPYLftSwf0WUfWw 40jw== 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 :arc-authentication-results; bh=2MkmEIC9hsF30jqdzNXJWH3iX+lXD/Pu//5DqUyc7ls=; b=vs3bFDN8zCthsOQkdK7wJlHtxa39sgrDH1IMkajHEFBmLRY+TYk5rx3WriRif5UgRi PzIsyPyk2EV5lVQZJVDQBIfw47Uoddxm+7yaVFUYqGhlBOtLLXBbdfGM7MQJE+bprHgP qhSvrWSyCfpeZaq6TcCH+3NhQlgfb3LTPNwRC43QpsvrWhQ06eQXsZx+a6EFkibeiyP4 H637966anZxqdkrbvkOCCosrJC5XoDZLcrCDyNAmgfLB2UJK/tYeTYXHzgv44MaY372j tr/Yf4SnVsM5Rv6FTLRKwtHVx1QKLKpnz/D0VPgAM+XaMpg6HXmXt6UugCz3D0IB1xFi 7XwA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@wdc.com header.s=dkim.wdc.com header.b=Okltj6sl; 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 v34-v6si21026416plg.491.2018.08.16.02.33.27; Thu, 16 Aug 2018 02:33:43 -0700 (PDT) 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=Okltj6sl; 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 S2388776AbeHPIsT (ORCPT + 99 others); Thu, 16 Aug 2018 04:48:19 -0400 Received: from esa4.hgst.iphmx.com ([216.71.154.42]:32958 "EHLO esa4.hgst.iphmx.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726205AbeHPIsS (ORCPT ); Thu, 16 Aug 2018 04:48:18 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=wdc.com; i=@wdc.com; q=dns/txt; s=dkim.wdc.com; t=1534398740; x=1565934740; h=subject:to:cc:references:from:message-id:date: mime-version:in-reply-to:content-transfer-encoding; bh=brzD7XOz41WXMJ5ddgZSZW5XbJCahR1BfVVOjO0lBd4=; b=Okltj6slmTsaDaWKInZ6dGPUagtKNJlFHAN9xMUaPsUVbkJdmheYW5VZ WEfMSqHHcZUkz6aaCuA4bMxtflv9LLTjSyUsckHDq7n367LPzn8TyfcHe wLz6aBHDP48+lsSnNWtOOLzmh5IU73dlNlTbFt5xXg0UAdtgaxxJ0Y3OU Jb3ISv9gNiuuN7yBvHkWsbDpZM1N+wUJU2gsuuvHEY2po1pEeLNA1aOHG bucoJgjpq3W1CN0dNpNATTbJrnjA1ZC2qSkJf3YGDFYxE/wl7byWbqHba 5pc19w2S/e9Yk6fVJSg9fYsKvDjqA6H1Lpi9p5ZLFzN3aA+dO/wQtKn/L A==; X-IronPort-AV: E=Sophos;i="5.53,246,1531756800"; d="scan'208";a="87694549" Received: from uls-op-cesaip01.wdc.com (HELO uls-op-cesaep01.wdc.com) ([199.255.45.14]) by ob1.hgst.iphmx.com with ESMTP; 16 Aug 2018 13:52:19 +0800 Received: from uls-op-cesaip02.wdc.com ([10.248.3.37]) by uls-op-cesaep01.wdc.com with ESMTP; 15 Aug 2018 22:40:17 -0700 Received: from 570dpc2.ad.shared (HELO [10.86.59.225]) ([10.86.59.225]) by uls-op-cesaip02.wdc.com with ESMTP; 15 Aug 2018 22:52:19 -0700 Subject: Re: [RFC PATCH 2/5] RISC-V: Use Linux logical cpu number instead of hartid To: Anup Patel Cc: "palmer@sifive.com" , "linux-riscv@lists.infradead.org" , Mark Rutland , Christoph Hellwig , Thomas Gleixner , "linux-kernel@vger.kernel.org List" , Damien Le Moal References: <1534377377-70108-1-git-send-email-atish.patra@wdc.com> <1534377377-70108-3-git-send-email-atish.patra@wdc.com> From: Atish Patra Message-ID: Date: Wed, 15 Aug 2018 22:52:15 -0700 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.12; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: 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 8/15/18 10:45 PM, Anup Patel wrote: > On Thu, Aug 16, 2018 at 10:53 AM, Atish Patra wrote: >> On 8/15/18 9:24 PM, Anup Patel wrote: >>> >>> On Thu, Aug 16, 2018 at 5:26 AM, Atish Patra wrote: >>>> >>>> Setup the cpu_logical_map during boot. Moreover, every SBI call >>>> and PLIC context are based on the physical hartid. Use the logical >>>> cpu to hartid mapping to pass correct hartid to respective functions. >>>> >>>> Signed-off-by: Atish Patra >>>> --- >>>> arch/riscv/include/asm/tlbflush.h | 17 +++++++++++++---- >>>> arch/riscv/kernel/cpu.c | 4 +++- >>>> arch/riscv/kernel/setup.c | 10 ++++++++++ >>>> arch/riscv/kernel/smp.c | 24 +++++++++++++++--------- >>>> arch/riscv/kernel/smpboot.c | 30 ++++++++++++++++++------------ >>>> drivers/clocksource/riscv_timer.c | 12 ++++++++---- >>>> drivers/irqchip/irq-sifive-plic.c | 11 +++++++---- >>>> 7 files changed, 74 insertions(+), 34 deletions(-) >>>> >>>> diff --git a/arch/riscv/include/asm/tlbflush.h >>>> b/arch/riscv/include/asm/tlbflush.h >>>> index 85c2d8ba..ecfd9b0e 100644 >>>> --- a/arch/riscv/include/asm/tlbflush.h >>>> +++ b/arch/riscv/include/asm/tlbflush.h >>>> @@ -16,6 +16,7 @@ >>>> #define _ASM_RISCV_TLBFLUSH_H >>>> >>>> #include >>>> +#include >>>> >>>> /* >>>> * Flush entire local TLB. 'sfence.vma' implicitly fences with the >>>> instruction >>>> @@ -49,13 +50,21 @@ static inline void flush_tlb_range(struct >>>> vm_area_struct *vma, >>>> >>>> #include >>>> >>>> -#define flush_tlb_all() sbi_remote_sfence_vma(NULL, 0, -1) >>>> +static inline void remote_sfence_vma(struct cpumask *cmask, unsigned >>>> long start, >>>> + unsigned long size) >>>> +{ >>>> + struct cpumask hmask; >>>> + >>>> + cpuid_to_hartid_mask(cmask, &hmask); >>>> + sbi_remote_sfence_vma(hmask.bits, start, size); >>>> +} >>>> + >>>> +#define flush_tlb_all() remote_sfence_vma(NULL, 0, -1) >>>> #define flush_tlb_page(vma, addr) flush_tlb_range(vma, addr, 0) >>>> #define flush_tlb_range(vma, start, end) \ >>>> - sbi_remote_sfence_vma(mm_cpumask((vma)->vm_mm)->bits, \ >>>> - start, (end) - (start)) >>>> + remote_sfence_vma(mm_cpumask((vma)->vm_mm), start, (end) - >>>> (start)) >>>> #define flush_tlb_mm(mm) \ >>>> - sbi_remote_sfence_vma(mm_cpumask(mm)->bits, 0, -1) >>>> + remote_sfence_vma(mm_cpumask(mm), 0, -1) >>>> >>>> #endif /* CONFIG_SMP */ >>>> >>>> diff --git a/arch/riscv/kernel/cpu.c b/arch/riscv/kernel/cpu.c >>>> index ca6c81e5..f8a18ace 100644 >>>> --- a/arch/riscv/kernel/cpu.c >>>> +++ b/arch/riscv/kernel/cpu.c >>>> @@ -14,6 +14,7 @@ >>>> #include >>>> #include >>>> #include >>>> +#include >>>> >>>> /* Return -1 if not a valid hart */ >>>> int riscv_of_processor_hart(struct device_node *node) >>>> @@ -79,7 +80,8 @@ static void c_stop(struct seq_file *m, void *v) >>>> static int c_show(struct seq_file *m, void *v) >>>> { >>>> unsigned long hart_id = (unsigned long)v - 1; >>>> - struct device_node *node = of_get_cpu_node(hart_id, NULL); >>>> + struct device_node *node = >>>> of_get_cpu_node(cpu_logical_map(hart_id), >>>> + NULL); >>> >>> >>> The hart_id is misleading name here. It should be cpu_id. Please replace >>> all instances of hart_id with cpu_id and where hard ID is to be displayed >>> use cpu_logical_map(cpu_id). >>> >> Correct. Thanks for catching it. I will fix it in v2. >> >> >>>> const char *compat, *isa, *mmu; >>>> >>>> seq_printf(m, "hart\t: %lu\n", hart_id); >>>> diff --git a/arch/riscv/kernel/setup.c b/arch/riscv/kernel/setup.c >>>> index e21ed481..97b586f8 100644 >>>> --- a/arch/riscv/kernel/setup.c >>>> +++ b/arch/riscv/kernel/setup.c >>>> @@ -84,6 +84,16 @@ atomic_t hart_lottery; >>>> >>>> u64 __cpu_logical_map[NR_CPUS]; >>>> >>>> +void __init smp_setup_processor_id(void) >>>> +{ >>>> + int cpu = smp_processor_id(); >>>> + >>>> + cpu_logical_map(0) = cpu; >>> >>> >>> I think this should be: >>> cpu_logical_map(cpu) = hart_id; >>> >>> Here hart_id for boot CPU will be value of a0 register passed at >>> boot-time. >>> >> I will change the variable name to hart_id. The assembly code in head.S have >> already stored hart id in thread info structure. So smp_processor_id() and >> hart id would be the same. >> >> > > I guess this means that for boot CPU, cpuid == hartid > No. I set the cpuid 0 for boot cpu by doing this. + /* Change the boot cpu ID in thread_info */ + current->thread_info.cpu = 0; > This is very confusing because other places I see CPU0 is the boot CPU. > CPU0 is the boot cpu. > I think assembly code in head.S should store 0 in thread info for boot CPU. > If we do that, we loose track of boot cpu hartid. We have to store it somewhere else to update the cpu_logical_map(0). Isn't it ? Regards, Atish > Regards, > Anup >