[PATCH v1 1/1] video: bridge-uclass: add get_display_timing ops

Simon Glass sjg at chromium.org
Sat Feb 15 18:24:13 CET 2025


Hi Svyatoslav,

On Sat, 15 Feb 2025 at 08:52, Svyatoslav Ryhel <clamor95 at gmail.com> wrote:
>
> Add get_display_timing ops for internal bridges linked to
> panels that do not support EDID (MIPI-DSI panels for example)
> or have EDID not routed.
>
> Signed-off-by: Svyatoslav Ryhel <clamor95 at gmail.com>
> ---
>  drivers/video/bridge/video-bridge-uclass.c | 11 +++++++++++
>  include/video_bridge.h                     | 18 ++++++++++++++++++
>  2 files changed, 29 insertions(+)

This should have a test, e.g. in test/dm/video.c or similar.

>
> diff --git a/drivers/video/bridge/video-bridge-uclass.c b/drivers/video/bridge/video-bridge-uclass.c
> index 2084a2e03ee..1b8aa12b9e8 100644
> --- a/drivers/video/bridge/video-bridge-uclass.c
> +++ b/drivers/video/bridge/video-bridge-uclass.c
> @@ -33,6 +33,17 @@ int video_bridge_attach(struct udevice *dev)
>         return ops->attach(dev);
>  }
>
> +int video_bridge_get_display_timing(struct udevice *dev,
> +                                   struct display_timing *timings)
> +{
> +       struct video_bridge_ops *ops = video_bridge_get_ops(dev);
> +
> +       if (!ops->get_display_timing)
> +               return -ENOSYS;
> +
> +       return ops->get_display_timing(dev, timings);
> +}
> +
>  int video_bridge_check_attached(struct udevice *dev)
>  {
>         struct video_bridge_priv *uc_priv = dev_get_uclass_priv(dev);
> diff --git a/include/video_bridge.h b/include/video_bridge.h
> index 3b429eac578..3860bf2cfee 100644
> --- a/include/video_bridge.h
> +++ b/include/video_bridge.h
> @@ -53,6 +53,16 @@ struct video_bridge_ops {
>          */
>         int (*set_backlight)(struct udevice *dev, int percent);
>
> +       /**
> +        * get_display_timing() - Get display timings from bridge.
> +        *
> +        * @dev:        Bridge device containing the linked display timings
> +        * @tim:        Place to put timings
> +        * @return 0 if OK, -ve on error
> +        */
> +       int (*get_display_timing)(struct udevice *dev,
> +                                 struct display_timing *timing);
> +
>         /**
>          * read_edid() - Read information from EDID
>          *
> @@ -98,6 +108,14 @@ int video_bridge_set_active(struct udevice *dev, bool active);
>   */
>  int video_bridge_check_attached(struct udevice *dev);
>
> +/**
> + * video_bridge_get_display_timing() - Get display timings from bridge.
> + *
> + * @dev:       Bridge device containing the linked display timings
> + * Return: 0 if OK, -ve on error
> + */
> +int video_bridge_get_display_timing(struct udevice *dev,
> +                                   struct display_timing *timing);
>  /**
>   * video_bridge_read_edid() - Read information from EDID
>   *
> --
> 2.43.0
>

Regards,
Simon


More information about the U-Boot mailing list