On 09/05/2025 11:12, Louis-Alexis Eyraud wrote:
> In the panfrost driver, the platform data of several Mediatek SoC
> declares and uses several different power domains arrays according to
> GPU core number present in the SoC:
> - mediatek_mt8186_pm_domains (2 cores)
> - mediatek_mt8183_pm_domains (3 cores)
> - mediatek_mt8192_pm_domains (5 cores)
> 
> As they all are fixed arrays, starting with the same entries and the
> platform data also has a power domains array length field
> (num_pm_domains), they can be replaced by a single array, containing
> all entries, if the num_pm_domains field of the platform data is also
> set to the matching core number.
> 
> So, create a generic power domain array (mediatek_pm_domains) and use
> it in the mt8183(b), mt8186, mt8188 and mt8192 platform data instead.
> 
> Signed-off-by: Louis-Alexis Eyraud <louisalexis.eyr...@collabora.com>

Reviewed-by: Steven Price <steven.pr...@arm.com>

> ---
>  drivers/gpu/drm/panfrost/panfrost_drv.c | 27 ++++++++++++---------------
>  1 file changed, 12 insertions(+), 15 deletions(-)
> 
> diff --git a/drivers/gpu/drm/panfrost/panfrost_drv.c 
> b/drivers/gpu/drm/panfrost/panfrost_drv.c
> index 
> 7b899a9b2120c608e61dab9ca831ab8e907e8139..21b28bef84015793d9dba6b1e585891dc0dfcb6d
>  100644
> --- a/drivers/gpu/drm/panfrost/panfrost_drv.c
> +++ b/drivers/gpu/drm/panfrost/panfrost_drv.c
> @@ -789,6 +789,8 @@ static const struct panfrost_compatible amlogic_data = {
>       .vendor_quirk = panfrost_gpu_amlogic_quirk,
>  };
>  
> +static const char * const mediatek_pm_domains[] = { "core0", "core1", 
> "core2",
> +                                                 "core3", "core4" };
>  /*
>   * The old data with two power supplies for MT8183 is here only to
>   * keep retro-compatibility with older devicetrees, as DVFS will
> @@ -798,48 +800,43 @@ static const struct panfrost_compatible amlogic_data = {
>   * coupled regulators instead.
>   */
>  static const char * const legacy_supplies[] = { "mali", "sram", NULL };
> -static const char * const mediatek_mt8183_pm_domains[] = { "core0", "core1", 
> "core2" };
>  static const struct panfrost_compatible mediatek_mt8183_data = {
>       .num_supplies = ARRAY_SIZE(legacy_supplies) - 1,
>       .supply_names = legacy_supplies,
> -     .num_pm_domains = ARRAY_SIZE(mediatek_mt8183_pm_domains),
> -     .pm_domain_names = mediatek_mt8183_pm_domains,
> +     .num_pm_domains = 3,
> +     .pm_domain_names = mediatek_pm_domains,
>  };
>  
>  static const struct panfrost_compatible mediatek_mt8183_b_data = {
>       .num_supplies = ARRAY_SIZE(default_supplies) - 1,
>       .supply_names = default_supplies,
> -     .num_pm_domains = ARRAY_SIZE(mediatek_mt8183_pm_domains),
> -     .pm_domain_names = mediatek_mt8183_pm_domains,
> +     .num_pm_domains = 3,
> +     .pm_domain_names = mediatek_pm_domains,
>       .pm_features = BIT(GPU_PM_CLK_DIS) | BIT(GPU_PM_VREG_OFF),
>  };
>  
> -static const char * const mediatek_mt8186_pm_domains[] = { "core0", "core1" 
> };
>  static const struct panfrost_compatible mediatek_mt8186_data = {
>       .num_supplies = ARRAY_SIZE(default_supplies) - 1,
>       .supply_names = default_supplies,
> -     .num_pm_domains = ARRAY_SIZE(mediatek_mt8186_pm_domains),
> -     .pm_domain_names = mediatek_mt8186_pm_domains,
> +     .num_pm_domains = 2,
> +     .pm_domain_names = mediatek_pm_domains,
>       .pm_features = BIT(GPU_PM_CLK_DIS) | BIT(GPU_PM_VREG_OFF),
>  };
>  
> -/* MT8188 uses the same power domains and power supplies as MT8183 */
>  static const struct panfrost_compatible mediatek_mt8188_data = {
>       .num_supplies = ARRAY_SIZE(default_supplies) - 1,
>       .supply_names = default_supplies,
> -     .num_pm_domains = ARRAY_SIZE(mediatek_mt8183_pm_domains),
> -     .pm_domain_names = mediatek_mt8183_pm_domains,
> +     .num_pm_domains = 3,
> +     .pm_domain_names = mediatek_pm_domains,
>       .pm_features = BIT(GPU_PM_CLK_DIS) | BIT(GPU_PM_VREG_OFF),
>       .gpu_quirks = BIT(GPU_QUIRK_FORCE_AARCH64_PGTABLE),
>  };
>  
> -static const char * const mediatek_mt8192_pm_domains[] = { "core0", "core1", 
> "core2",
> -                                                        "core3", "core4" };
>  static const struct panfrost_compatible mediatek_mt8192_data = {
>       .num_supplies = ARRAY_SIZE(default_supplies) - 1,
>       .supply_names = default_supplies,
> -     .num_pm_domains = ARRAY_SIZE(mediatek_mt8192_pm_domains),
> -     .pm_domain_names = mediatek_mt8192_pm_domains,
> +     .num_pm_domains = 5,
> +     .pm_domain_names = mediatek_pm_domains,
>       .pm_features = BIT(GPU_PM_CLK_DIS) | BIT(GPU_PM_VREG_OFF),
>       .gpu_quirks = BIT(GPU_QUIRK_FORCE_AARCH64_PGTABLE),
>  };
> 

Reply via email to