On Wed, Aug 20, 2025 at 09:15:36AM +0200, Maxime Ripard wrote: > Hi, > > On Tue, Aug 19, 2025 at 09:57:30PM +0300, Dmitry Baryshkov wrote: > > Currently DRM framework expects that the HDMI connector driver supports > > all infoframe types: it generates the data as required and calls into > > the driver to program all of them, letting the driver to soft-fail if > > the infoframe is unsupported. This has a major drawback on userspace > > API: the framework also registers debugfs files for all Infoframe types, > > possibly surprising the users when infoframe is visible in the debugfs > > file, but it is not visible on the wire. > > > > Let drivers declare that they support only a subset of infoframes, > > creating a more consistent interface. > > > > Signed-off-by: Dmitry Baryshkov <[email protected]> > > I'm not really convinced. Infoframes aren't really something you should > ignore, AVI is effectively mandatory, HDMI kind of is too, AUDIO is if > audio support is enabled, DRM is mandatory if HDR is used.
Nevertheless, sun4i, innohdmi, adv7511, it6263 and rk3066 drivers provide support only for the AVI infoframe. Some of them can be extended to support other infoframe kinds (e.g. ADV7511 has two spare infoframes which can be used for HDMI and SPD). > SPD is indeed optional though. > > So, it's really dynamic in essence, and not really something we should > expect drivers to ignore. > > I do acknowledge that a lot of drivers just silently ignore the > infoframes they don't support at the moment, which isn't great either. > > Maybe we should standardize and document what drivers should do when > they don't support a given infoframe type? The chips might be generating infoframes internally. This series was triggered by LT9611UXC, which does all HDMI work under the hood in the firmware. See [1]. The series I posted hooks HDMI audio directly into the bridge driver, but I'd really prefer to be able to use drm_atomic_helper_connector_hdmi_hotplug(), especially if I ever get to implementing CEC support for it. ADV7511 likewise generates audio infoframe without Linux help (audio-related fields are programmed, but it's not the infoframe itself). Maybe I should change documentation for this field as 'support sending infoframes generated by the Linux kernel'. > Something like return EOPNOTSUPP if you don't support it, and we warn in > the core if we get one for a mandatory infoframe? [1] https://lore.kernel.org/dri-devel/[email protected]/ -- With best wishes Dmitry
