[PATCH v2 3/4] lib: sbi: fwft: Fix error return value for feature > 32 bits

Clément Léger cleger at rivosinc.com
Mon Feb 24 01:20:05 PST 2025



On 19/02/2025 17:49, Anup Patel wrote:
> On Fri, Jan 24, 2025 at 10:23 PM Clément Léger <cleger at rivosinc.com> wrote:
>>
>> Based on the spec, invalid feature should return SBI_ERR_INVALID_PARAM.
>> This was not the case with the current implementation since the upper 32
>> bits were not considered when checking the feature thus returning
>> SBI_ERR_DENIED. Fix that by passing the raw unsigned long rather than
>> the enum to be sure we are passing the full 64 bits and then check for
>> upper bits to be cleared.
>>
>> Signed-off-by: Clément Léger <cleger at rivosinc.com>
>> ---
>>  include/sbi/sbi_fwft.h |  4 ++--
>>  lib/sbi/sbi_fwft.c     | 10 +++++++---
>>  2 files changed, 9 insertions(+), 5 deletions(-)
>>
>> diff --git a/include/sbi/sbi_fwft.h b/include/sbi/sbi_fwft.h
>> index 2148820e..a9caa863 100644
>> --- a/include/sbi/sbi_fwft.h
>> +++ b/include/sbi/sbi_fwft.h
>> @@ -14,9 +14,9 @@
>>
>>  struct sbi_scratch;
>>
>> -int sbi_fwft_set(enum sbi_fwft_feature_t feature, unsigned long value,
>> +int sbi_fwft_set(unsigned long feature, unsigned long value,
>>                  unsigned long flags);
>> -int sbi_fwft_get(enum sbi_fwft_feature_t feature, unsigned long *out_val);
>> +int sbi_fwft_get(unsigned long feature, unsigned long *out_val);
> 
> The feature should be uint32_t as defined by the SBI spec.
> 
> Also, the uint32_t overflow check if required should be done in
> sbi_ecall_fwft_handler().

Yes, I'll re-spin that patch with the SSE one as well.

Thanks,

Clément

> 
> Regards,
> Anup
> 
>>
>>  int sbi_fwft_init(struct sbi_scratch *scratch, bool cold_boot);
>>
>> diff --git a/lib/sbi/sbi_fwft.c b/lib/sbi/sbi_fwft.c
>> index c46006d4..85f8a638 100644
>> --- a/lib/sbi/sbi_fwft.c
>> +++ b/lib/sbi/sbi_fwft.c
>> @@ -287,12 +287,16 @@ static struct fwft_config* get_feature_config(enum sbi_fwft_feature_t feature)
>>         return NULL;
>>  }
>>
>> -static int fwft_get_feature(enum sbi_fwft_feature_t feature,
>> +static int fwft_get_feature(unsigned long feature,
>>                             struct fwft_config **conf)
>>  {
>>         int ret;
>>         struct fwft_config *tconf;
>>
>> +       /* Feature are defined as 32 bits identifiers */
>> +       if (feature & ~(BIT_ULL(32) - 1))
>> +               return SBI_EINVAL;
>> +
>>         tconf = get_feature_config(feature);
>>         if (!tconf) {
>>                 if (fwft_is_defined_feature(feature))
>> @@ -323,7 +327,7 @@ static void fwft_clear_config_lock(enum sbi_fwft_feature_t feature)
>>         conf->flags &= ~SBI_FWFT_SET_FLAG_LOCK;
>>  }
>>
>> -int sbi_fwft_set(enum sbi_fwft_feature_t feature, unsigned long value,
>> +int sbi_fwft_set(unsigned long feature, unsigned long value,
>>                  unsigned long flags)
>>  {
>>         int ret;
>> @@ -348,7 +352,7 @@ int sbi_fwft_set(enum sbi_fwft_feature_t feature, unsigned long value,
>>         return SBI_OK;
>>  }
>>
>> -int sbi_fwft_get(enum sbi_fwft_feature_t feature, unsigned long *out_val)
>> +int sbi_fwft_get(unsigned long feature, unsigned long *out_val)
>>  {
>>         int ret;
>>         struct fwft_config *conf;
>> --
>> 2.47.1
>>
>>
>> --
>> opensbi mailing list
>> opensbi at lists.infradead.org
>> http://lists.infradead.org/mailman/listinfo/opensbi




More information about the opensbi mailing list