All of lore.kernel.org
 help / color / mirror / Atom feed
From: Atish Patra <atish.patra@linux.dev>
To: "Clément Léger" <cleger@rivosinc.com>,
	"Paul Walmsley" <paul.walmsley@sifive.com>,
	"Palmer Dabbelt" <palmer@dabbelt.com>,
	"Anup Patel" <anup@brainfault.org>,
	"Atish Patra" <atishp@atishpatra.org>,
	"Shuah Khan" <shuah@kernel.org>,
	"Jonathan Corbet" <corbet@lwn.net>,
	linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org,
	linux-doc@vger.kernel.org, kvm@vger.kernel.org,
	kvm-riscv@lists.infradead.org, linux-kselftest@vger.kernel.org
Cc: Samuel Holland <samuel.holland@sifive.com>,
	Andrew Jones <ajones@ventanamicro.com>,
	Deepak Gupta <debug@rivosinc.com>
Subject: Re: [PATCH v6 05/14] riscv: sbi: add SBI FWFT extension calls
Date: Thu, 8 May 2025 16:01:12 -0700	[thread overview]
Message-ID: <4032b00c-1194-45b1-b1e5-4e9237ed7948@linux.dev> (raw)
In-Reply-To: <20250424173204.1948385-6-cleger@rivosinc.com>

On 4/24/25 10:31 AM, Clément Léger wrote:
> Add FWFT extension calls. This will be ratified in SBI V3.0 hence, it is
> provided as a separate commit that can be left out if needed.
> 
> Signed-off-by: Clément Léger <cleger@rivosinc.com>
> Reviewed-by: Andrew Jones <ajones@ventanamicro.com>
> ---
>   arch/riscv/kernel/sbi.c | 20 +++++++++++++++++++-
>   1 file changed, 19 insertions(+), 1 deletion(-)
> 
> diff --git a/arch/riscv/kernel/sbi.c b/arch/riscv/kernel/sbi.c
> index d57e4dae7dac..070014ff35d4 100644
> --- a/arch/riscv/kernel/sbi.c
> +++ b/arch/riscv/kernel/sbi.c
> @@ -299,6 +299,8 @@ static int __sbi_rfence_v02(int fid, const struct cpumask *cpu_mask,
>   	return 0;
>   }
>   
> +static bool sbi_fwft_supported;
> +

super nit: Can declare this along with struct fwft_set_req so that they 
are together ? You can move the sbi_fwft_set to below the struct 
fwft_set_req.

>   /**
>    * sbi_fwft_set() - Set a feature on the local hart
>    * @feature: The feature ID to be set
> @@ -309,7 +311,15 @@ static int __sbi_rfence_v02(int fid, const struct cpumask *cpu_mask,
>    */
>   int sbi_fwft_set(u32 feature, unsigned long value, unsigned long flags)
>   {
> -	return -EOPNOTSUPP;
> +	struct sbiret ret;
> +
> +	if (!sbi_fwft_supported)
> +		return -EOPNOTSUPP;
> +
> +	ret = sbi_ecall(SBI_EXT_FWFT, SBI_EXT_FWFT_SET,
> +			feature, value, flags, 0, 0, 0);
> +
> +	return sbi_err_map_linux_errno(ret.error);
>   }
>   
>   struct fwft_set_req {
> @@ -348,6 +358,9 @@ int sbi_fwft_set_cpumask(const cpumask_t *mask, u32 feature,
>   		.error = ATOMIC_INIT(0),
>   	};
>   
> +	if (!sbi_fwft_supported)
> +		return -EOPNOTSUPP;
> +
>   	if (feature & SBI_FWFT_GLOBAL_FEATURE_BIT)
>   		return -EINVAL;
>   
> @@ -679,6 +692,11 @@ void __init sbi_init(void)
>   			pr_info("SBI DBCN extension detected\n");
>   			sbi_debug_console_available = true;
>   		}
> +		if (sbi_spec_version >= sbi_mk_version(3, 0) &&
> +		    sbi_probe_extension(SBI_EXT_FWFT)) {
> +			pr_info("SBI FWFT extension detected\n");
> +			sbi_fwft_supported = true;
> +		}
>   	} else {
>   		__sbi_set_timer = __sbi_set_timer_v01;
>   		__sbi_send_ipi	= __sbi_send_ipi_v01;

Otherwise, LGTM.

Reviewed-by: Atish Patra <atishp@rivosinc.com>

-- 
kvm-riscv mailing list
kvm-riscv@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/kvm-riscv

WARNING: multiple messages have this Message-ID (diff)
From: Atish Patra <atish.patra@linux.dev>
To: "Clément Léger" <cleger@rivosinc.com>,
	"Paul Walmsley" <paul.walmsley@sifive.com>,
	"Palmer Dabbelt" <palmer@dabbelt.com>,
	"Anup Patel" <anup@brainfault.org>,
	"Atish Patra" <atishp@atishpatra.org>,
	"Shuah Khan" <shuah@kernel.org>,
	"Jonathan Corbet" <corbet@lwn.net>,
	linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org,
	linux-doc@vger.kernel.org, kvm@vger.kernel.org,
	kvm-riscv@lists.infradead.org, linux-kselftest@vger.kernel.org
Cc: Samuel Holland <samuel.holland@sifive.com>,
	Andrew Jones <ajones@ventanamicro.com>,
	Deepak Gupta <debug@rivosinc.com>
Subject: Re: [PATCH v6 05/14] riscv: sbi: add SBI FWFT extension calls
Date: Thu, 8 May 2025 16:01:12 -0700	[thread overview]
Message-ID: <4032b00c-1194-45b1-b1e5-4e9237ed7948@linux.dev> (raw)
In-Reply-To: <20250424173204.1948385-6-cleger@rivosinc.com>

On 4/24/25 10:31 AM, Clément Léger wrote:
> Add FWFT extension calls. This will be ratified in SBI V3.0 hence, it is
> provided as a separate commit that can be left out if needed.
> 
> Signed-off-by: Clément Léger <cleger@rivosinc.com>
> Reviewed-by: Andrew Jones <ajones@ventanamicro.com>
> ---
>   arch/riscv/kernel/sbi.c | 20 +++++++++++++++++++-
>   1 file changed, 19 insertions(+), 1 deletion(-)
> 
> diff --git a/arch/riscv/kernel/sbi.c b/arch/riscv/kernel/sbi.c
> index d57e4dae7dac..070014ff35d4 100644
> --- a/arch/riscv/kernel/sbi.c
> +++ b/arch/riscv/kernel/sbi.c
> @@ -299,6 +299,8 @@ static int __sbi_rfence_v02(int fid, const struct cpumask *cpu_mask,
>   	return 0;
>   }
>   
> +static bool sbi_fwft_supported;
> +

super nit: Can declare this along with struct fwft_set_req so that they 
are together ? You can move the sbi_fwft_set to below the struct 
fwft_set_req.

>   /**
>    * sbi_fwft_set() - Set a feature on the local hart
>    * @feature: The feature ID to be set
> @@ -309,7 +311,15 @@ static int __sbi_rfence_v02(int fid, const struct cpumask *cpu_mask,
>    */
>   int sbi_fwft_set(u32 feature, unsigned long value, unsigned long flags)
>   {
> -	return -EOPNOTSUPP;
> +	struct sbiret ret;
> +
> +	if (!sbi_fwft_supported)
> +		return -EOPNOTSUPP;
> +
> +	ret = sbi_ecall(SBI_EXT_FWFT, SBI_EXT_FWFT_SET,
> +			feature, value, flags, 0, 0, 0);
> +
> +	return sbi_err_map_linux_errno(ret.error);
>   }
>   
>   struct fwft_set_req {
> @@ -348,6 +358,9 @@ int sbi_fwft_set_cpumask(const cpumask_t *mask, u32 feature,
>   		.error = ATOMIC_INIT(0),
>   	};
>   
> +	if (!sbi_fwft_supported)
> +		return -EOPNOTSUPP;
> +
>   	if (feature & SBI_FWFT_GLOBAL_FEATURE_BIT)
>   		return -EINVAL;
>   
> @@ -679,6 +692,11 @@ void __init sbi_init(void)
>   			pr_info("SBI DBCN extension detected\n");
>   			sbi_debug_console_available = true;
>   		}
> +		if (sbi_spec_version >= sbi_mk_version(3, 0) &&
> +		    sbi_probe_extension(SBI_EXT_FWFT)) {
> +			pr_info("SBI FWFT extension detected\n");
> +			sbi_fwft_supported = true;
> +		}
>   	} else {
>   		__sbi_set_timer = __sbi_set_timer_v01;
>   		__sbi_send_ipi	= __sbi_send_ipi_v01;

Otherwise, LGTM.

Reviewed-by: Atish Patra <atishp@rivosinc.com>

WARNING: multiple messages have this Message-ID (diff)
From: Atish Patra <atish.patra@linux.dev>
To: "Clément Léger" <cleger@rivosinc.com>,
	"Paul Walmsley" <paul.walmsley@sifive.com>,
	"Palmer Dabbelt" <palmer@dabbelt.com>,
	"Anup Patel" <anup@brainfault.org>,
	"Atish Patra" <atishp@atishpatra.org>,
	"Shuah Khan" <shuah@kernel.org>,
	"Jonathan Corbet" <corbet@lwn.net>,
	linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org,
	linux-doc@vger.kernel.org, kvm@vger.kernel.org,
	kvm-riscv@lists.infradead.org, linux-kselftest@vger.kernel.org
Cc: Samuel Holland <samuel.holland@sifive.com>,
	Andrew Jones <ajones@ventanamicro.com>,
	Deepak Gupta <debug@rivosinc.com>
Subject: Re: [PATCH v6 05/14] riscv: sbi: add SBI FWFT extension calls
Date: Thu, 8 May 2025 16:01:12 -0700	[thread overview]
Message-ID: <4032b00c-1194-45b1-b1e5-4e9237ed7948@linux.dev> (raw)
In-Reply-To: <20250424173204.1948385-6-cleger@rivosinc.com>

On 4/24/25 10:31 AM, Clément Léger wrote:
> Add FWFT extension calls. This will be ratified in SBI V3.0 hence, it is
> provided as a separate commit that can be left out if needed.
> 
> Signed-off-by: Clément Léger <cleger@rivosinc.com>
> Reviewed-by: Andrew Jones <ajones@ventanamicro.com>
> ---
>   arch/riscv/kernel/sbi.c | 20 +++++++++++++++++++-
>   1 file changed, 19 insertions(+), 1 deletion(-)
> 
> diff --git a/arch/riscv/kernel/sbi.c b/arch/riscv/kernel/sbi.c
> index d57e4dae7dac..070014ff35d4 100644
> --- a/arch/riscv/kernel/sbi.c
> +++ b/arch/riscv/kernel/sbi.c
> @@ -299,6 +299,8 @@ static int __sbi_rfence_v02(int fid, const struct cpumask *cpu_mask,
>   	return 0;
>   }
>   
> +static bool sbi_fwft_supported;
> +

super nit: Can declare this along with struct fwft_set_req so that they 
are together ? You can move the sbi_fwft_set to below the struct 
fwft_set_req.

>   /**
>    * sbi_fwft_set() - Set a feature on the local hart
>    * @feature: The feature ID to be set
> @@ -309,7 +311,15 @@ static int __sbi_rfence_v02(int fid, const struct cpumask *cpu_mask,
>    */
>   int sbi_fwft_set(u32 feature, unsigned long value, unsigned long flags)
>   {
> -	return -EOPNOTSUPP;
> +	struct sbiret ret;
> +
> +	if (!sbi_fwft_supported)
> +		return -EOPNOTSUPP;
> +
> +	ret = sbi_ecall(SBI_EXT_FWFT, SBI_EXT_FWFT_SET,
> +			feature, value, flags, 0, 0, 0);
> +
> +	return sbi_err_map_linux_errno(ret.error);
>   }
>   
>   struct fwft_set_req {
> @@ -348,6 +358,9 @@ int sbi_fwft_set_cpumask(const cpumask_t *mask, u32 feature,
>   		.error = ATOMIC_INIT(0),
>   	};
>   
> +	if (!sbi_fwft_supported)
> +		return -EOPNOTSUPP;
> +
>   	if (feature & SBI_FWFT_GLOBAL_FEATURE_BIT)
>   		return -EINVAL;
>   
> @@ -679,6 +692,11 @@ void __init sbi_init(void)
>   			pr_info("SBI DBCN extension detected\n");
>   			sbi_debug_console_available = true;
>   		}
> +		if (sbi_spec_version >= sbi_mk_version(3, 0) &&
> +		    sbi_probe_extension(SBI_EXT_FWFT)) {
> +			pr_info("SBI FWFT extension detected\n");
> +			sbi_fwft_supported = true;
> +		}
>   	} else {
>   		__sbi_set_timer = __sbi_set_timer_v01;
>   		__sbi_send_ipi	= __sbi_send_ipi_v01;

Otherwise, LGTM.

Reviewed-by: Atish Patra <atishp@rivosinc.com>

_______________________________________________
linux-riscv mailing list
linux-riscv@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-riscv

  reply	other threads:[~2025-05-08 23:01 UTC|newest]

Thread overview: 96+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-04-24 17:31 [PATCH v6 00/14] riscv: add SBI FWFT misaligned exception delegation support Clément Léger
2025-04-24 17:31 ` Clément Léger
2025-04-24 17:31 ` Clément Léger
2025-04-24 17:31 ` [PATCH v6 01/14] riscv: sbi: add Firmware Feature (FWFT) SBI extensions definitions Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-05-08 20:17   ` Atish Patra
2025-05-08 20:17     ` Atish Patra
2025-05-08 20:17     ` Atish Patra
2025-04-24 17:31 ` [PATCH v6 02/14] riscv: sbi: remove useless parenthesis Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-04-25  7:46   ` Andrew Jones
2025-04-25  7:46     ` Andrew Jones
2025-04-25  7:46     ` Andrew Jones
2025-05-08 20:18   ` Atish Patra
2025-05-08 20:18     ` Atish Patra
2025-05-08 20:18     ` Atish Patra
2025-04-24 17:31 ` [PATCH v6 03/14] riscv: sbi: add new SBI error mappings Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-05-08 20:18   ` Atish Patra
2025-05-08 20:18     ` Atish Patra
2025-05-08 20:18     ` Atish Patra
2025-04-24 17:31 ` [PATCH v6 04/14] riscv: sbi: add FWFT extension interface Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-05-08 22:52   ` Atish Patra
2025-05-08 22:52     ` Atish Patra
2025-05-08 22:52     ` Atish Patra
2025-05-09  0:18   ` Atish Patra
2025-05-09  0:18     ` Atish Patra
2025-05-09  0:18     ` Atish Patra
2025-05-12  8:14     ` Clément Léger
2025-05-12  8:14       ` Clément Léger
2025-05-12  8:14       ` Clément Léger
2025-05-12 18:00       ` Atish Patra
2025-05-12 18:00         ` Atish Patra
2025-05-12 18:00         ` Atish Patra
2025-04-24 17:31 ` [PATCH v6 05/14] riscv: sbi: add SBI FWFT extension calls Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-05-08 23:01   ` Atish Patra [this message]
2025-05-08 23:01     ` Atish Patra
2025-05-08 23:01     ` Atish Patra
2025-04-24 17:31 ` [PATCH v6 06/14] riscv: misaligned: request misaligned exception from SBI Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-04-24 17:31 ` [PATCH v6 07/14] riscv: misaligned: use on_each_cpu() for scalar misaligned access probing Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-04-24 17:31 ` [PATCH v6 08/14] riscv: misaligned: use correct CONFIG_ ifdef for misaligned_access_speed Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-04-24 17:31 ` [PATCH v6 09/14] riscv: misaligned: move emulated access uniformity check in a function Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-04-24 17:31 ` [PATCH v6 10/14] riscv: misaligned: add a function to check misalign trap delegability Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-04-24 18:18   ` ALOK TIWARI
2025-04-24 18:18     ` ALOK TIWARI
2025-04-24 18:18     ` ALOK TIWARI
2025-04-24 17:31 ` [PATCH v6 11/14] RISC-V: KVM: add SBI extension init()/deinit() functions Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-05-08 17:27   ` Palmer Dabbelt
2025-05-08 17:27     ` Palmer Dabbelt
2025-05-08 17:27     ` Palmer Dabbelt
2025-05-09  3:20     ` Anup Patel
2025-05-09  3:20       ` Anup Patel
2025-05-09  3:20       ` Anup Patel
2025-05-09  0:26   ` Atish Patra
2025-05-09  0:26     ` Atish Patra
2025-05-09  0:26     ` Atish Patra
2025-04-24 17:31 ` [PATCH v6 12/14] RISC-V: KVM: add SBI extension reset callback Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-04-24 17:31   ` Clément Léger
2025-05-09  0:28   ` Atish Patra
2025-05-09  0:28     ` Atish Patra
2025-05-09  0:28     ` Atish Patra
2025-04-24 17:32 ` [PATCH v6 13/14] RISC-V: KVM: add support for FWFT SBI extension Clément Léger
2025-04-24 17:32   ` Clément Léger
2025-04-24 17:32   ` Clément Léger
2025-05-09 18:49   ` Atish Patra
2025-05-09 18:49     ` Atish Patra
2025-05-09 18:49     ` Atish Patra
2025-04-24 17:32 ` [PATCH v6 14/14] RISC-V: KVM: add support for SBI_FWFT_MISALIGNED_DELEG Clément Léger
2025-04-24 17:32   ` Clément Léger
2025-04-24 17:32   ` Clément Léger
2025-05-09 18:09   ` Atish Patra
2025-05-09 18:09     ` Atish Patra
2025-05-09 18:09     ` Atish Patra
2025-05-12  8:28     ` Clément Léger
2025-05-12  8:28       ` Clément Léger
2025-05-12  8:28       ` Clément Léger

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=4032b00c-1194-45b1-b1e5-4e9237ed7948@linux.dev \
    --to=atish.patra@linux.dev \
    --cc=ajones@ventanamicro.com \
    --cc=anup@brainfault.org \
    --cc=atishp@atishpatra.org \
    --cc=cleger@rivosinc.com \
    --cc=corbet@lwn.net \
    --cc=debug@rivosinc.com \
    --cc=kvm-riscv@lists.infradead.org \
    --cc=kvm@vger.kernel.org \
    --cc=linux-doc@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-kselftest@vger.kernel.org \
    --cc=linux-riscv@lists.infradead.org \
    --cc=palmer@dabbelt.com \
    --cc=paul.walmsley@sifive.com \
    --cc=samuel.holland@sifive.com \
    --cc=shuah@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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.