[PATCH v2 4/4] lib: sbi: Clear lock only for local events
Andrew Jones
ajones at ventanamicro.com
Mon Mar 24 08:37:14 PDT 2025
On Fri, Jan 24, 2025 at 05:51:59PM +0100, Clément Léger wrote:
> Upon hart reset, only the local events state should be reset. While this
> implicitely worked since fwft_get_feature() return NULL for global
> events this is a bit fragile to do so. Additionally, the loop on feature
> list plus the call to fwft_get_feature was unneeded since we already have
> a direct access to the fwft hart state and thus can directly reset lock
> flags for each config. Lastly, we can only clear the lock when the fwft
> hart state was already allocated, in the other case, it is allocated with
> a zalloc which guarantees us that the feature flags are clear at boot.
>
> Signed-off-by: Clément Léger <cleger at rivosinc.com>
> ---
> lib/sbi/sbi_fwft.c | 26 ++++++++++++++++----------
> 1 file changed, 16 insertions(+), 10 deletions(-)
>
> diff --git a/lib/sbi/sbi_fwft.c b/lib/sbi/sbi_fwft.c
> index 85f8a638..d946e9db 100644
> --- a/lib/sbi/sbi_fwft.c
> +++ b/lib/sbi/sbi_fwft.c
> @@ -271,12 +271,17 @@ static int fwft_get_pmlen(struct fwft_config *conf, unsigned long *value)
> }
> #endif
>
> +static bool fwft_feature_is_global(enum sbi_fwft_feature_t feature)
> +{
> + return feature & SBI_FWFT_GLOBAL_FEATURE_BIT;
> +}
> +
> static struct fwft_config* get_feature_config(enum sbi_fwft_feature_t feature)
> {
> int i;
> struct fwft_hart_state *fhs = fwft_thishart_state_ptr();
>
> - if (feature & SBI_FWFT_GLOBAL_FEATURE_BIT)
> + if (fwft_feature_is_global(feature))
> return NULL;
>
> for (i = 0; i < fhs->config_count; i++){
> @@ -315,16 +320,18 @@ static int fwft_get_feature(unsigned long feature,
> return SBI_SUCCESS;
> }
>
> -static void fwft_clear_config_lock(enum sbi_fwft_feature_t feature)
> +static void fwft_clear_local_lock(struct fwft_hart_state *fhs)
> {
> - int ret;
> + int i;
> struct fwft_config *conf;
>
> - ret = fwft_get_feature(feature, &conf);
> - if (ret)
> - return;
> + for (i = 0; i < fhs->config_count; i++) {
> + conf = &fhs->configs[i];
> + if (fwft_feature_is_global(conf->feature->id))
> + continue;
>
> - conf->flags &= ~SBI_FWFT_SET_FLAG_LOCK;
> + conf->flags &= ~SBI_FWFT_SET_FLAG_LOCK;
> + }
> }
>
> int sbi_fwft_set(unsigned long feature, unsigned long value,
> @@ -428,10 +435,9 @@ int sbi_fwft_init(struct sbi_scratch *scratch, bool cold_boot)
> fhs->configs[i].feature = &features[i];
>
> fwft_set_hart_state_ptr(scratch, fhs);
> + } else {
> + fwft_clear_local_lock(fhs);
> }
>
> - for (i = 0; i < array_size(features); i++)
> - fwft_clear_config_lock(features[i].id);
> -
> return 0;
> }
> --
> 2.47.1
>
Reviewed-by: Andrew Jones <ajones at ventanamicro.com>
More information about the opensbi
mailing list