media: i2c: adv748x: Report correct DV timings for pattern generator
authorNiklas Söderlund <niklas.soderlund+renesas@ragnatech.se>
Wed, 22 Feb 2023 22:12:49 +0000 (23:12 +0100)
committerHans Verkuil <hverkuil-cisco@xs4all.nl>
Tue, 11 Apr 2023 15:10:10 +0000 (17:10 +0200)
If the pattern generator is enabled the device shall not be queried for
timings. Instead the timings programmed shall be reported as they are
the ones being used to generate the pattern.

Before this change an external HDMI source needed to be connected for
the pattern generator to work. The driver would query this external
HDMI source for timings and program the pattern generator using those.

With this change the user can control the timings and have the pattern
generator work without the need of an external HDMI source being
connected.

Signed-off-by: Niklas Söderlund <niklas.soderlund+renesas@ragnatech.se>
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
drivers/media/i2c/adv748x/adv748x-hdmi.c

index 47688d1..400d71c 100644 (file)
@@ -283,6 +283,16 @@ static int adv748x_hdmi_query_dv_timings(struct v4l2_subdev *sd,
 
        memset(timings, 0, sizeof(struct v4l2_dv_timings));
 
+       /*
+        * If the pattern generator is enabled the device shall not be queried
+        * for timings. Instead the timings programmed shall be reported as they
+        * are the ones being used to generate the pattern.
+        */
+       if (cp_read(state, ADV748X_CP_PAT_GEN) & ADV748X_CP_PAT_GEN_EN) {
+               *timings = hdmi->timings;
+               return 0;
+       }
+
        if (!adv748x_hdmi_has_signal(state))
                return -ENOLINK;