Received: by 2002:a05:7208:9594:b0:7e:5202:c8b4 with SMTP id gs20csp2139178rbb; Tue, 27 Feb 2024 11:49:33 -0800 (PST) X-Forwarded-Encrypted: i=3; AJvYcCV3fsMQPmnzqmkhP3D6LNamMB4T1h7WO6QP5mOOTlXYlo2ac5o/tfinzmE5J9hZ7M2A2cMB1vK3XpDz9/03Sqf5EfCWjWky/JvE2+3Cpg== X-Google-Smtp-Source: AGHT+IHL+1L07+hBcojBZOJ42I9Nixra+ysVNdKq2TG6+rCLpriTg1/zjgu+crVr2lOzVrQu8yl2 X-Received: by 2002:a17:90a:bd98:b0:299:e313:b0ad with SMTP id z24-20020a17090abd9800b00299e313b0admr9726036pjr.9.1709063373309; Tue, 27 Feb 2024 11:49:33 -0800 (PST) ARC-Seal: i=2; a=rsa-sha256; t=1709063373; cv=pass; d=google.com; s=arc-20160816; b=xzj902N76PgcluL5rC8KuPAHf/z8c62jA7RWOzT1zCyJs9xS3VRofidrsrXq7RNI+e Vwu5LFQ+lSAT9fo/HZgsbSUEj96SNq/jJ9RMv4MsnicM2wpfsoKDXXB21fSWdANdh7xG pISwiY44qfDQtd5SoUghEXuiZUvslwrstdcNvtvwMjxz5stNnSMyOU6379qbUgpGuPXm 4seWjjeU9yYigXOljCAXefiKrYnNeXDmhqARmg9xGs0cTpHMCp5rLKW86yfQxhWys+nJ 2h52fxw9Gdys7668ev7enIARaqYxkSUK1453zTF6lP8Rmsj1PCToRHGZA4HGhFri5CX1 6PbA== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:date:message-id; bh=96Gwzst3rMhPp8WPPgVuqgmY32v8dAakUR492dn4Cto=; fh=/eCpL6uOos+ApNGIJeGbQ/PEtD3QciyHHGNOv/TPCqM=; b=uJCPAAXhJHmCDCBqtQMFVM1f2Y9rCfJFkOeMBcoX5LScx7iUG0Q3jEmiHXyV1DHJWM DO4QBpLV7WuRyW1FBmTWdHXPxU6wBUopcdyxVAVUxg6RY/uNdycsatfrFmHAehjILphX ddypy7FCldq3SwZI+oaANwjHbGSTorJFCfGhLZN1Erfe0hHp9F3i6H7NNRxR8jEexAZ/ Wrq2pDC01mUzNmFB1rekFjDZsjzr9sI/w6opQ+oVaJb9jHYdGsK8OdjdsbmKh4ishrkx gH10rqdiURm2cAllc1Lfuc+ywSJe6eFUYZt5q+Plzj0l+5/KTOQiMLeSdCBQVPRRs7aO 52Dw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; arc=pass (i=1 spf=pass spfdomain=ghiti.fr); spf=pass (google.com: domain of linux-kernel+bounces-83953-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-83953-linux.lists.archive=gmail.com@vger.kernel.org" Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [139.178.88.99]) by mx.google.com with ESMTPS id il10-20020a17090b164a00b00295f1aea266si6063031pjb.89.2024.02.27.11.49.33 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 27 Feb 2024 11:49:33 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel+bounces-83953-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) client-ip=139.178.88.99; Authentication-Results: mx.google.com; arc=pass (i=1 spf=pass spfdomain=ghiti.fr); spf=pass (google.com: domain of linux-kernel+bounces-83953-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-83953-linux.lists.archive=gmail.com@vger.kernel.org" Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id D17EB283E44 for ; Tue, 27 Feb 2024 19:49:32 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id CE33A14A4CB; Tue, 27 Feb 2024 19:49:00 +0000 (UTC) Received: from relay9-d.mail.gandi.net (relay9-d.mail.gandi.net [217.70.183.199]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id C85F113AA27; Tue, 27 Feb 2024 19:48:57 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=217.70.183.199 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709063340; cv=none; b=AELF6b+Kb28+WMfSccZpWjmLld3kh97qxy1drnZXjaonP1fvi1036g/hicgVxVk0ci2hd/mczJxSieSiNyMQne4swoxlYBgH9h0x7a1fKm6BLyZCAYgL7m4z0/H8kxkoeacUnKuu59eKu32zgTaXlwuO8ob8wRPiV4yLyNHx/kg= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1709063340; c=relaxed/simple; bh=T4NRM4qBfwkx48BHPpCSmvWo4swu8CkEHCR2aja6ssg=; h=Message-ID:Date:MIME-Version:Subject:To:Cc:References:From: In-Reply-To:Content-Type; b=l/OfqAcLcJ0Exn7dsM3r3j1JJfE51HqVTtAUMcwBubuiOh3QeZGbri5Fm8NPdUkZ+9n5dUERByp2ktHBtXF2XvEixLJtBnVdkaxiOOmYVJoiHzdDB/E1tPZ8/aWR0Q3eXqqb4RZcRunSTdQpan7xF38RzTuCaKsRYEKHqKTeDsY= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=ghiti.fr; spf=pass smtp.mailfrom=ghiti.fr; arc=none smtp.client-ip=217.70.183.199 Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=ghiti.fr Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=ghiti.fr Received: by mail.gandi.net (Postfix) with ESMTPSA id 56C4BFF802; Tue, 27 Feb 2024 19:48:55 +0000 (UTC) Message-ID: <579c9f3f-8c28-4e4e-88ce-9f266597b7bd@ghiti.fr> Date: Tue, 27 Feb 2024 20:48:54 +0100 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH -fixes v3 1/2] riscv: Fix enabling cbo.zero when running in M-mode Content-Language: en-US To: Andrew Jones , Samuel Holland Cc: Palmer Dabbelt , linux-kernel@vger.kernel.org, Conor Dooley , linux-riscv@lists.infradead.org, Stefan O'Rear , stable@vger.kernel.org References: <20240214090206.195754-1-samuel.holland@sifive.com> <20240214090206.195754-2-samuel.holland@sifive.com> <20240214-661604d82db4ef137540b762@orel> From: Alexandre Ghiti In-Reply-To: <20240214-661604d82db4ef137540b762@orel> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-GND-Sasl: alex@ghiti.fr 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: >> Fixes: 43c16d51a19b ("RISC-V: Enable cbo.zero in usermode") >> Reviewed-by: Andrew Jones >> Signed-off-by: Samuel Holland >> --- >> >> (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