Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp1794205imm; Thu, 16 Aug 2018 02:45:21 -0700 (PDT) X-Google-Smtp-Source: AA+uWPzbjgDgGiGSiB4NnzulimEJ8P8QY2eQPbF5MHptjTNVKJfIqw0RXhnOqxTfruotBErY1xJZ X-Received: by 2002:a17:902:ab94:: with SMTP id f20-v6mr27896732plr.231.1534412721648; Thu, 16 Aug 2018 02:45:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1534412721; cv=none; d=google.com; s=arc-20160816; b=NNBReWnwbn2D5HIXKAq6ESOc7k1Tc8gOe36bMarf6jj1wC6M6r+O2WF5VVe0FEsv+V X0+ORO2UqLVoId6F7/wXdRSfNrx4VYTqLs6a1XSyb5TBM/VVueolmNu28eg/FYvV+iJK Z7oTk0rXj2nC0co5RsOB+mbNcAQ37ddaP2Hbf6zSRuh41RRoIRHUgj8tt594Uo2a6swC lrkUTRxb2sxmlseKe3ecXwM+4xBka8WbWDHXyZkk8vN6AgLw+dL0Ta4K39H44ewaGORu 7j37VaIDnDbaNH4QKnkhqFpnpuInEls5EOo8Ya3Ab2Rq7MGRPziNEll4y9nBqriyThBB ifRg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :references:in-reply-to:mime-version:dkim-signature :arc-authentication-results; bh=iv7541+CGlaxOTE4DBW7D8Mp2BbBuLBexXUL5CPW7Vc=; b=aRoYaohY+IMjsVKkL9Q/ud94xmcI2BNFG+R0A77mUhIxgo/ZJ0D/IYkJPtokyuyCoO 4tnhPeskkRSYT4RrRf4sniLo/vlbaOzr0yUuc7d2GCRRkppAWFuTAeK44HJaLA16MvSZ uSavtUTvucwivy6beW6gWmqbOteK1Eg/VjNVNY8aOCm0s9fwlzGIAqt2bkrGJFmtMthy Edr9N/NalsFz/fLzJnR00NR1gCZGmxKu7fQE8oEZWlIRBPki29MUTciFz4Y/V8fNF39L 72zKvUYeDUocxb7qdHJCjBFG3usbjNsNKTq3PNN+p/KTHgSabxF15khn2IzjDYx+LBrI WsFQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@brainfault-org.20150623.gappssmtp.com header.s=20150623 header.b=mrRzaFZx; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b12-v6si26309625pgh.264.2018.08.16.02.44.51; Thu, 16 Aug 2018 02:45:21 -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=pass header.i=@brainfault-org.20150623.gappssmtp.com header.s=20150623 header.b=mrRzaFZx; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388800AbeHPI75 (ORCPT + 99 others); Thu, 16 Aug 2018 04:59:57 -0400 Received: from mail-wr1-f65.google.com ([209.85.221.65]:45618 "EHLO mail-wr1-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388787AbeHPI75 (ORCPT ); Thu, 16 Aug 2018 04:59:57 -0400 Received: by mail-wr1-f65.google.com with SMTP id f12-v6so2999226wrv.12 for ; Wed, 15 Aug 2018 23:03:52 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=brainfault-org.20150623.gappssmtp.com; s=20150623; h=mime-version:in-reply-to:references:from:date:message-id:subject:to :cc; bh=iv7541+CGlaxOTE4DBW7D8Mp2BbBuLBexXUL5CPW7Vc=; b=mrRzaFZxNgF+PGmtqSdu1tAb3YrTqJaMS3Wd4PR/0CGfjUPXgWUXNyXrW4nIW3SOiz iQOmHsQiRqfROJRDhREWyVhdj9EiZyMtl591uFvobamd23q5SUaiIRwwZQJr+86VbsVM 5Q3buiM6P57oaGkYynbEEJEC62vvEf0AM0f5NNXacZXIGErwnQ2I/44Wp2YeaklwKY2d 5yr1UVvZhxf9kH6uCb52nelVUT1JCr1+SvoTkXBpbjQA8meJs7DiIjKmIIcAohtzjL4u u2RUXZJT6ULh5H+7jhQN5kp2YtLkkJ7MRY2EtW9iEmJ17/8LB/rndIebZjMYJJoxkY7S wa8Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:in-reply-to:references:from:date :message-id:subject:to:cc; bh=iv7541+CGlaxOTE4DBW7D8Mp2BbBuLBexXUL5CPW7Vc=; b=E2BaZHhyEjhrdes4EpQSilcERsrxdVTdo35UGFzZ6LzqTCv3X4ex9cAb90uixQsCas CWCzhqTVLtHG2ZOR0qdL7Guw3MJYvplgZJErPPdznRDEHoEHxJs1xIforcNFH5t4+q8w j0Vgb8tNSAu/XnyrfDZNHk4LCROupmC06y2VcgNi6Wg8m1c5H2N2CSuCnHA3pHxsk/pf W+HVO0aMHAz5gCfQo94Gy6I6MbPCY+Tzu6WGRqfDYzz78DQsuSEX2FbnL+pL5fzzJgGh B10YUrt1u8V/7Ltz2tS2vK1q3Z1yA09tI3Av/sFnkEJkoOqdErDWjh+Yl9V0qGVo7DiU 0fQQ== X-Gm-Message-State: AOUpUlGqeMUOCKATOhp3hfYyluiDy5SrKD5MnxeT6cQwVs81m3RQe9tg Kr9b5jPaLprJZo39nPoX3DJ1/XzEZlTl1Yby03BSeA== X-Received: by 2002:adf:aadb:: with SMTP id i27-v6mr18731517wrc.149.1534399431349; Wed, 15 Aug 2018 23:03:51 -0700 (PDT) MIME-Version: 1.0 Received: by 2002:adf:9dd2:0:0:0:0:0 with HTTP; Wed, 15 Aug 2018 23:03:50 -0700 (PDT) In-Reply-To: References: <1534377377-70108-1-git-send-email-atish.patra@wdc.com> <1534377377-70108-3-git-send-email-atish.patra@wdc.com> From: Anup Patel Date: Thu, 16 Aug 2018 11:33:50 +0530 Message-ID: Subject: Re: [RFC PATCH 2/5] RISC-V: Use Linux logical cpu number instead of hartid To: Atish Patra Cc: "palmer@sifive.com" , "linux-riscv@lists.infradead.org" , Mark Rutland , Christoph Hellwig , Thomas Gleixner , "linux-kernel@vger.kernel.org List" , Damien Le Moal Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Aug 16, 2018 at 11:22 AM, Atish Patra wrote: > 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 ? We can have variable of machine word size declared in assembly named "boot_cpu_hart_id" which will hold the hart ID of boot CPU. No need to update thread_info.cpu on boot CPU. In fact, set thread_info.cpu to 0 in head.S itself. Regards, Anup