From: Alexandre Ghiti <alex@ghiti.fr>
To: Andrew Jones <ajones@ventanamicro.com>,
Samuel Holland <samuel.holland@sifive.com>
Cc: Palmer Dabbelt <palmer@dabbelt.com>,
linux-kernel@vger.kernel.org, Conor Dooley <conor@kernel.org>,
linux-riscv@lists.infradead.org,
Stefan O'Rear <sorear@fastmail.com>,
stable@vger.kernel.org
Subject: Re: [PATCH -fixes v3 1/2] riscv: Fix enabling cbo.zero when running in M-mode
Date: Tue, 27 Feb 2024 20:48:54 +0100 [thread overview]
Message-ID: <579c9f3f-8c28-4e4e-88ce-9f266597b7bd@ghiti.fr> (raw)
In-Reply-To: <20240214-661604d82db4ef137540b762@orel>
Hi Samuel,
On 14/02/2024 10:28, Andrew Jones wrote:
> On Wed, Feb 14, 2024 at 01:01:56AM -0800, Samuel Holland wrote:
>> When the kernel is running in M-mode, the CBZE bit must be set in the
>> menvcfg CSR, not in senvcfg.
>>
>> Cc: <stable@vger.kernel.org>
>> Fixes: 43c16d51a19b ("RISC-V: Enable cbo.zero in usermode")
>> Reviewed-by: Andrew Jones <ajones@ventanamicro.com>
>> Signed-off-by: Samuel Holland <samuel.holland@sifive.com>
>> ---
>>
>> (no changes since v1)
>>
>> arch/riscv/include/asm/csr.h | 2 ++
>> arch/riscv/kernel/cpufeature.c | 2 +-
>> 2 files changed, 3 insertions(+), 1 deletion(-)
>>
>> diff --git a/arch/riscv/include/asm/csr.h b/arch/riscv/include/asm/csr.h
>> index 510014051f5d..2468c55933cd 100644
>> --- a/arch/riscv/include/asm/csr.h
>> +++ b/arch/riscv/include/asm/csr.h
>> @@ -424,6 +424,7 @@
>> # define CSR_STATUS CSR_MSTATUS
>> # define CSR_IE CSR_MIE
>> # define CSR_TVEC CSR_MTVEC
>> +# define CSR_ENVCFG CSR_MENVCFG
>> # define CSR_SCRATCH CSR_MSCRATCH
>> # define CSR_EPC CSR_MEPC
>> # define CSR_CAUSE CSR_MCAUSE
>> @@ -448,6 +449,7 @@
>> # define CSR_STATUS CSR_SSTATUS
>> # define CSR_IE CSR_SIE
>> # define CSR_TVEC CSR_STVEC
>> +# define CSR_ENVCFG CSR_SENVCFG
>> # define CSR_SCRATCH CSR_SSCRATCH
>> # define CSR_EPC CSR_SEPC
>> # define CSR_CAUSE CSR_SCAUSE
>> diff --git a/arch/riscv/kernel/cpufeature.c b/arch/riscv/kernel/cpufeature.c
>> index 89920f84d0a3..c5b13f7dd482 100644
>> --- a/arch/riscv/kernel/cpufeature.c
>> +++ b/arch/riscv/kernel/cpufeature.c
>> @@ -950,7 +950,7 @@ arch_initcall(check_unaligned_access_all_cpus);
>> void riscv_user_isa_enable(void)
>> {
>> if (riscv_cpu_has_extension_unlikely(smp_processor_id(), RISCV_ISA_EXT_ZICBOZ))
>> - csr_set(CSR_SENVCFG, ENVCFG_CBZE);
>> + csr_set(CSR_ENVCFG, ENVCFG_CBZE);
>> }
>>
>> #ifdef CONFIG_RISCV_ALTERNATIVE
>> --
>> 2.43.0
>>
> After our back and forth on how we determine the existence of the *envcfg
> CSRs, I wonder if we shouldn't put a comment above this
> riscv_user_isa_enable() function capturing the [current] decision.
>
> Something like
>
> /*
> * While the [ms]envcfg CSRs weren't defined until priv spec 1.12,
> * they're assumed to be present when an extension is present which
> * specifies [ms]envcfg bit(s). Hence, we don't do any additional
> * priv spec version checks or CSR probes here.
> */
I was about to read the whole discussion in v2 to understand the
v3...thank you Drew :) I think it really makes sense to add this
comment, do you intend to do so Samuel?
Thanks,
Alex
>
> Thanks,
> drew
>
> _______________________________________________
> linux-riscv mailing list
> linux-riscv@lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/linux-riscv
next prev parent reply other threads:[~2024-02-27 19:48 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <20240214090206.195754-1-samuel.holland@sifive.com>
2024-02-14 9:01 ` [PATCH -fixes v3 1/2] riscv: Fix enabling cbo.zero when running in M-mode Samuel Holland
2024-02-14 9:28 ` Andrew Jones
2024-02-27 19:48 ` Alexandre Ghiti [this message]
2024-02-27 20:01 ` Samuel Holland
2024-02-14 9:01 ` [PATCH -fixes v3 2/2] riscv: Save/restore envcfg CSR during CPU suspend Samuel Holland
2024-02-14 9:29 ` Andrew Jones
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=579c9f3f-8c28-4e4e-88ce-9f266597b7bd@ghiti.fr \
--to=alex@ghiti.fr \
--cc=ajones@ventanamicro.com \
--cc=conor@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-riscv@lists.infradead.org \
--cc=palmer@dabbelt.com \
--cc=samuel.holland@sifive.com \
--cc=sorear@fastmail.com \
--cc=stable@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox