|
@@ -674,6 +674,8 @@ static int hdmi_g_mbus_fmt(struct v4l2_subdev *sd,
|
|
static int hdmi_enum_dv_timings(struct v4l2_subdev *sd,
|
|
static int hdmi_enum_dv_timings(struct v4l2_subdev *sd,
|
|
struct v4l2_enum_dv_timings *timings)
|
|
struct v4l2_enum_dv_timings *timings)
|
|
{
|
|
{
|
|
|
|
+ if (timings->pad != 0)
|
|
|
|
+ return -EINVAL;
|
|
if (timings->index >= ARRAY_SIZE(hdmi_timings))
|
|
if (timings->index >= ARRAY_SIZE(hdmi_timings))
|
|
return -EINVAL;
|
|
return -EINVAL;
|
|
timings->timings = hdmi_timings[timings->index].dv_timings;
|
|
timings->timings = hdmi_timings[timings->index].dv_timings;
|
|
@@ -687,6 +689,9 @@ static int hdmi_dv_timings_cap(struct v4l2_subdev *sd,
|
|
{
|
|
{
|
|
struct hdmi_device *hdev = sd_to_hdmi_dev(sd);
|
|
struct hdmi_device *hdev = sd_to_hdmi_dev(sd);
|
|
|
|
|
|
|
|
+ if (cap->pad != 0)
|
|
|
|
+ return -EINVAL;
|
|
|
|
+
|
|
/* Let the phy fill in the pixelclock range */
|
|
/* Let the phy fill in the pixelclock range */
|
|
v4l2_subdev_call(hdev->phy_sd, video, dv_timings_cap, cap);
|
|
v4l2_subdev_call(hdev->phy_sd, video, dv_timings_cap, cap);
|
|
cap->type = V4L2_DV_BT_656_1120;
|
|
cap->type = V4L2_DV_BT_656_1120;
|
|
@@ -713,6 +718,11 @@ static const struct v4l2_subdev_video_ops hdmi_sd_video_ops = {
|
|
.s_stream = hdmi_s_stream,
|
|
.s_stream = hdmi_s_stream,
|
|
};
|
|
};
|
|
|
|
|
|
|
|
+static const struct v4l2_subdev_pad_ops hdmi_sd_pad_ops = {
|
|
|
|
+ .enum_dv_timings = hdmi_enum_dv_timings,
|
|
|
|
+ .dv_timings_cap = hdmi_dv_timings_cap,
|
|
|
|
+};
|
|
|
|
+
|
|
static const struct v4l2_subdev_ops hdmi_sd_ops = {
|
|
static const struct v4l2_subdev_ops hdmi_sd_ops = {
|
|
.core = &hdmi_sd_core_ops,
|
|
.core = &hdmi_sd_core_ops,
|
|
.video = &hdmi_sd_video_ops,
|
|
.video = &hdmi_sd_video_ops,
|