[PATCH v1 1/1] video: bridge-uclass: add get_display_timing ops
Simon Glass
sjg at chromium.org
Sat Feb 15 19:07:22 CET 2025
Hi Svyatoslav,
On Sat, 15 Feb 2025 at 10:42, Svyatoslav Ryhel <clamor95 at gmail.com> wrote:
>
> сб, 15 лют. 2025 р. о 19:24 Simon Glass <sjg at chromium.org> пише:
> >
> > 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.
> >
>
> I totally agree, but it seems that there is no tests for
> UCLASS_VIDEO_BRIDGE unless I am missing smth. May you pls point me to
> it? Maybe I can add simple bridge analog of linux driver as sandbox
> test case?
Oh dear, that's my fault. Yes, please add something simple.
>
> > >
> > > 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
Regards,
Simon
More information about the U-Boot
mailing list