On Wed, Jul 30, 2025 at 07:02:47PM +0200, Louis Chauvet wrote:
> As stated in the AM62x Technical Reference Manual (SPRUIV7B), the data
> sampling edge needs to be configured in two distinct registers: one in the
> TIDSS IP and another in the memory-mapped control register modules. Since
> the latter is not within the same address range, a phandle to a syscon
> device is used to access the regmap.
> 
> Fixes: 32a1795f57ee ("drm/tidss: New driver for TI Keystone platform Display 
> SubSystem")
> Signed-off-by: Louis Chauvet <louis.chau...@bootlin.com>
> 
> ---
> 
> Cc: sta...@vger.kernel.org

Please read docs how to add stable tags.

> ---
>  drivers/gpu/drm/tidss/tidss_dispc.c | 14 ++++++++++++++
>  1 file changed, 14 insertions(+)
> 
> diff --git a/drivers/gpu/drm/tidss/tidss_dispc.c 
> b/drivers/gpu/drm/tidss/tidss_dispc.c
> index 
> c0277fa36425ee1f966dccecf2b69a2d01794899..65ca7629a2e75437023bf58f8a1bddc24db5e3da
>  100644
> --- a/drivers/gpu/drm/tidss/tidss_dispc.c
> +++ b/drivers/gpu/drm/tidss/tidss_dispc.c
> @@ -498,6 +498,7 @@ struct dispc_device {
>       const struct dispc_features *feat;
>  
>       struct clk *fclk;
> +     struct regmap *clk_ctrl;
>  
>       bool is_enabled;
>  
> @@ -1267,6 +1268,11 @@ void dispc_vp_enable(struct dispc_device *dispc, u32 
> hw_videoport,
>                      FLD_VAL(mode->vdisplay - 1, 27, 16));
>  
>       VP_REG_FLD_MOD(dispc, hw_videoport, DISPC_VP_CONTROL, 1, 0, 0);
> +
> +     if (dispc->clk_ctrl) {
> +             regmap_update_bits(dispc->clk_ctrl, 0, 0x100, ipc ? 0x100 : 
> 0x000);
> +             regmap_update_bits(dispc->clk_ctrl, 0, 0x200, rf ? 0x200 : 
> 0x000);
> +     }
>  }
>  
>  void dispc_vp_disable(struct dispc_device *dispc, u32 hw_videoport)
> @@ -3012,6 +3018,14 @@ int dispc_init(struct tidss_device *tidss)
>  
>       dispc_init_errata(dispc);
>  
> +     dispc->clk_ctrl = 
> syscon_regmap_lookup_by_phandle_optional(tidss->dev->of_node,
> +                                                                
> "ti,clk-ctrl");
> +     if (IS_ERR(dispc->clk_ctrl)) {
> +             r = dev_err_probe(dispc->dev, PTR_ERR(dispc->clk_ctrl),
> +                               "DISPC: syscon_regmap_lookup_by_phandle 
> failed.\n");
> +             return r;

This breaks ABI. Commit msg mentions the reason but without
justification - was everything broken? Nothing was working? Was it ever
tested?

And anyway ABI impact must be clearly documented.


Best regards,
Krzysztof

Reply via email to