Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp2213503pxk; Sat, 26 Sep 2020 22:39:43 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyL5AJ+YdFZGx4lbBH1S1YxsHqIZaVAh8aHH1pBlqO5xLGZe07CO/S271PFDr5vWh/rTD9f X-Received: by 2002:a17:906:14ca:: with SMTP id y10mr9962993ejc.542.1601185183101; Sat, 26 Sep 2020 22:39:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601185183; cv=none; d=google.com; s=arc-20160816; b=qKzv4XkZml5zK7SE4ImROT7wMmz6q+ynCgSifSNIHn7MdO/AMmPY/oUDmF+8OuO3J9 ATCUSiS137PvlGM4Z9rOz9kVOIepKLGCLZaPJLKU1f9qUmNrM15gv8PesR06wzGCuuqq RJlydDKJ3hW2kykkGKFJapCzJ2SStBWNDcpfv/noZ4rkbqN88A441itb2UUclAGAH0ZF tkhhjKSIo525BzM4GmAr1xQhthk9prDSYE/vTUEi9Zf3/eYHpUxc7izD89ztNaRQUrBU JJW259itLnbwievR8lFSdFmFO8gQecb3kdudSxC4ynyQTnDE/Qd4vOEtiUK/MdAdRzwc JPpg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=YHDABiC4xj9iLU7za42e+/JActT5fY52ViGb3PJJENA=; b=thC4WW1+l6ElD954+EdzvfMEZAFik/l9wYLxgC8SsyGN3B5Z71Y5T0LLj0v7HZR2zM DgAx2aX58CD9WwGbPA5RlXvfyhSW9hCQCqeMLzGOG9LGaqL/+K3kskCcdDCDZ5Ia843r r3ZL3g660nMJQmYRVtgxPZI/PAGs8LDVWOizPBxuLbplxsJzu0Ql/Lo3xIWvthXvOeBD JGbgevyMG1jZqovR37L/ZkoYe8dWyftH8Hjn7iS4PheYtmCGf05xuJdS4+acEq6WNSM9 i6AMQ/yOC5PF5JfceEAxmKeO/oT9VtTE6JTeSYmPVHe4gUJ8Dm5OxepMfr9uouWmdjZa KE1Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@brainfault-org.20150623.gappssmtp.com header.s=20150623 header.b=awzKmx7u; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id n10si5506710ejk.73.2020.09.26.22.39.20; Sat, 26 Sep 2020 22:39:43 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@brainfault-org.20150623.gappssmtp.com header.s=20150623 header.b=awzKmx7u; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730215AbgI0Ffx (ORCPT + 99 others); Sun, 27 Sep 2020 01:35:53 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47580 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726382AbgI0Ffx (ORCPT ); Sun, 27 Sep 2020 01:35:53 -0400 Received: from mail-wr1-x444.google.com (mail-wr1-x444.google.com [IPv6:2a00:1450:4864:20::444]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id ED00AC0613CE for ; Sat, 26 Sep 2020 22:35:52 -0700 (PDT) Received: by mail-wr1-x444.google.com with SMTP id j2so8118174wrx.7 for ; Sat, 26 Sep 2020 22:35:52 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=brainfault-org.20150623.gappssmtp.com; s=20150623; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=YHDABiC4xj9iLU7za42e+/JActT5fY52ViGb3PJJENA=; b=awzKmx7uwTTIV8k7hfxFozgeg68RC5QUa3CALzs2AvYLepl8s/IfrKrVYR+zw7K02U UzLnhynMS9hIhM6HigzdNWReGMTY+w/5ptAPlZ03nZ8elVLvMN78AQT3uBFfbcxLJYTC 3ApNUO2J8F0+VqnNZRwM3/m6aczqW0TaT25dn4Ss59T4PUmt7dCYzqNsDXjOoCJqRr2u WuttwYW4sCWL7nlWL2q2eTidSOaLE6OCoStOgHE+NJV69142dQ1fs5bBeFj92CFNL6ef 82gMJqBXFtOwUCiSqlfjBuba9KnapMnDW6bQ8nVUT103iu7EVUHK8BWqIRAjTsf/TSi9 Y80A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=YHDABiC4xj9iLU7za42e+/JActT5fY52ViGb3PJJENA=; b=Zteir8zfXSTA1XjNOvojHR2oNx8Un1XA5nBT9ZYc6eqy32QhEiG5Bbi95jYviCwfIG jKOSYtDAkVsntnL//o9W1ES5sIM6lpsWa64nqpiw/aF7KNplcE2CqJ+3TiEZixXh1JLZ vus720lGC3qFAAVG3VGdQbG6KjtBYxu+ydl12bubN6J6o5mH6HLNO15FYEv7vgc1OAwZ clV7yYqvvo/HZ9/qo++kVQ7e+U+qOXW53kMv9y7/lxSc00hsMjNon9lzQ37+ENmkc2rD +wS+XKYiOe4Z1mV1pZWVPVu6jd8w6frWgUGyppSJ+/VTfuK/li4zbjz0NDowMPZLX8fG rGWw== X-Gm-Message-State: AOAM532O9p2zC9dxZY61tucRtmf0BNUU0a7+xWT3zvrN/fjJwERpVHeJ pHtdSBQwTrpF0GhqtlCbtoG5WhaRPySqbIGoGjPr18rwb2/mGQ== X-Received: by 2002:adf:db48:: with SMTP id f8mr12823535wrj.144.1601184951403; Sat, 26 Sep 2020 22:35:51 -0700 (PDT) MIME-Version: 1.0 References: <4950cd11fcf66bc3606f309d6289577b5dc65b2e.camel@wdc.com> In-Reply-To: From: Anup Patel Date: Sun, 27 Sep 2020 11:05:39 +0530 Message-ID: Subject: Re: [PATCH v2] RISC-V: Check clint_time_val before use To: Palmer Dabbelt Cc: Damien Le Moal , Paul Walmsley , Anup Patel , Albert Ou , linux-riscv , Atish Patra , Alistair Francis , "linux-kernel@vger.kernel.org List" Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, Sep 27, 2020 at 5:50 AM Palmer Dabbelt wrote: > > On Sat, 26 Sep 2020 03:31:29 PDT (-0700), Damien Le Moal wrote: > > On Sat, 2020-09-26 at 15:51 +0530, Anup Patel wrote: > >> The NoMMU kernel is broken for QEMU virt machine from Linux-5.9-rc6 > >> because the get_cycles() and friends are called very early from > >> rand_initialize() before CLINT driver is probed. To fix this, we > >> should check clint_time_val before use in get_cycles() and friends. > > I don't think this is the right way to solve that problem, as we're essentially > just lying about the timer rather than informing the system we can't get > timer-based entropy right now. MIPS is explicit about this, I don't see any > reason why we shouldn't be as well. > > Does this fix the boot issue (see below for the NULL)? There's some other > random-related arch functions so this might not be quite the right way to do > it. > > diff --git a/arch/riscv/include/asm/timex.h b/arch/riscv/include/asm/timex.h > index 7f659dda0032..7e39b0068932 100644 > --- a/arch/riscv/include/asm/timex.h > +++ b/arch/riscv/include/asm/timex.h > @@ -33,6 +33,18 @@ static inline u32 get_cycles_hi(void) > #define get_cycles_hi get_cycles_hi > #endif /* CONFIG_64BIT */ > > +/* > + * Much like MIPS, we may not have a viable counter to use at an early point in > + * the boot process. Unfortunately we don't have a fallback, so instead we > + * just return 0. > + */ > +static inline unsigned long random_get_entropy(void) > +{ > + if (unlikely(clint_time_val == NULL)) > + return 0; > + return get_cycles(); > +} > + Overall, this approach is good but this change is incomplete so does not work. The linux/timex.h expects random_get_entropy() to be macro so we need a "#define" as well. After fixing rand_initialize() with custom random_get_entropy(), we get another issue in boot_init_stack_canary() because boot_init_stack_canary() directly calls get_cycles() so we remove use of get_cycles() from boot_init_stack_canary() and this is similar to ARM, ARM64, and MIPS kernel. Regards, Anup > #else /* CONFIG_RISCV_M_MODE */ > > static inline cycles_t get_cycles(void) > > >> Fixes: d5be89a8d118 ("RISC-V: Resurrect the MMIO timer implementation > >> for M-mode systems") > >> Signed-off-by: Anup Patel > >> --- > >> Changes since v1: > >> - Explicitly initialize clint_time_val to NULL in CLINT driver to > >> avoid hang on Kendryte K210 > >> --- > >> arch/riscv/include/asm/timex.h | 12 +++++++++--- > >> drivers/clocksource/timer-clint.c | 2 +- > >> 2 files changed, 10 insertions(+), 4 deletions(-) > >> > >> diff --git a/arch/riscv/include/asm/timex.h b/arch/riscv/include/asm/timex.h > >> index 7f659dda0032..6e7b04874755 100644 > >> --- a/arch/riscv/include/asm/timex.h > >> +++ b/arch/riscv/include/asm/timex.h > >> @@ -17,18 +17,24 @@ typedef unsigned long cycles_t; > >> #ifdef CONFIG_64BIT > >> static inline cycles_t get_cycles(void) > >> { > >> - return readq_relaxed(clint_time_val); > >> + if (clint_time_val) > >> + return readq_relaxed(clint_time_val); > >> + return 0; > >> } > >> #else /* !CONFIG_64BIT */ > >> static inline u32 get_cycles(void) > >> { > >> - return readl_relaxed(((u32 *)clint_time_val)); > >> + if (clint_time_val) > >> + return readl_relaxed(((u32 *)clint_time_val)); > >> + return 0; > >> } > >> #define get_cycles get_cycles > >> > >> static inline u32 get_cycles_hi(void) > >> { > >> - return readl_relaxed(((u32 *)clint_time_val) + 1); > >> + if (clint_time_val) > >> + return readl_relaxed(((u32 *)clint_time_val) + 1); > >> + return 0; > >> } > >> #define get_cycles_hi get_cycles_hi > >> #endif /* CONFIG_64BIT */ > >> diff --git a/drivers/clocksource/timer-clint.c b/drivers/clocksource/timer-clint.c > >> index d17367dee02c..8dbec85979fd 100644 > >> --- a/drivers/clocksource/timer-clint.c > >> +++ b/drivers/clocksource/timer-clint.c > >> @@ -37,7 +37,7 @@ static unsigned long clint_timer_freq; > >> static unsigned int clint_timer_irq; > >> > >> #ifdef CONFIG_RISCV_M_MODE > >> -u64 __iomem *clint_time_val; > >> +u64 __iomem *clint_time_val = NULL; > > This one I definately don't get. According the internet, the C standard says > > If an object that has static storage duration is not initialized > explicitly, it is initialized implicitly as if every member that has > arithmetic type were assigned 0 and every member that has pointer type were > assigned a null pointer constant. > > so unless I'm missing something there shouldn't be any difference between these > two lines. When I just apply this I get exactly the same "objdump -dt" before > and after. I do see some difference in assembly, but only when I don't pass > "-fno-common" and that ends up being passed during my Linux builds. > > >> #endif > >> > >> static void clint_send_ipi(const struct cpumask *target) > > > > For Kendryte: > > > > Tested-by: Damien Le Moal > > > > -- > > Damien Le Moal > > Western Digital