[PATCH v5 3/5] lib: sbi_platform: expose hart_features to extension_init callback

Anup Patel anup at brainfault.org
Wed Oct 12 21:08:19 PDT 2022


On Tue, Oct 4, 2022 at 10:13 PM Heiko Stuebner <heiko at sntech.de> wrote:
>
> The platform-specific extension_init callback is supposed to
> set specific things for the platform opensbi is running on.
>
> So it's also the right place to override specific hart_features
> if needed - when it's know that autodetection has provided
> wrong results for example.
>
> Suggested-by: Atish Patra <atishp at atishpatra.org>
> Signed-off-by: Heiko Stuebner <heiko at sntech.de>

Looks good to me.

Reviewed-by: Anup Patel <anup at brainfault.org>

Regards,
Anup

> ---
>  include/sbi/sbi_platform.h | 8 +++++---
>  lib/sbi/sbi_hart.c         | 3 ++-
>  2 files changed, 7 insertions(+), 4 deletions(-)
>
> diff --git a/include/sbi/sbi_platform.h b/include/sbi/sbi_platform.h
> index 87024db..722f27a 100644
> --- a/include/sbi/sbi_platform.h
> +++ b/include/sbi/sbi_platform.h
> @@ -48,6 +48,7 @@
>  struct sbi_domain_memregion;
>  struct sbi_trap_info;
>  struct sbi_trap_regs;
> +struct sbi_hart_features;
>
>  /** Possible feature flags of a platform */
>  enum sbi_platform_features {
> @@ -90,7 +91,7 @@ struct sbi_platform_operations {
>         int (*misa_get_xlen)(void);
>
>         /** Initialize (or populate) HART extensions for the platform */
> -       int (*extensions_init)(void);
> +       int (*extensions_init)(struct sbi_hart_features *hfeatures);
>
>         /** Initialize (or populate) domains for the platform */
>         int (*domains_init)(void);
> @@ -464,10 +465,11 @@ static inline int sbi_platform_misa_xlen(const struct sbi_platform *plat)
>   * @return 0 on success and negative error code on failure
>   */
>  static inline int sbi_platform_extensions_init(
> -                                       const struct sbi_platform *plat)
> +                                       const struct sbi_platform *plat,
> +                                       struct sbi_hart_features *hfeatures)
>  {
>         if (plat && sbi_platform_ops(plat)->extensions_init)
> -               return sbi_platform_ops(plat)->extensions_init();
> +               return sbi_platform_ops(plat)->extensions_init(hfeatures);
>         return 0;
>  }
>
> diff --git a/lib/sbi/sbi_hart.c b/lib/sbi/sbi_hart.c
> index d0a6295..dacab1a 100644
> --- a/lib/sbi/sbi_hart.c
> +++ b/lib/sbi/sbi_hart.c
> @@ -672,7 +672,8 @@ __mhpm_skip:
>         }
>
>         /* Let platform populate extensions */
> -       rc = sbi_platform_extensions_init(sbi_platform_thishart_ptr());
> +       rc = sbi_platform_extensions_init(sbi_platform_thishart_ptr(),
> +                                         hfeatures);
>         if (rc)
>                 return rc;
>
> --
> 2.35.1
>
>
> --
> opensbi mailing list
> opensbi at lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/opensbi



More information about the opensbi mailing list