Commit 680fee04 authored by Hans Verkuil's avatar Hans Verkuil Committed by Mauro Carvalho Chehab

[media] adv: use V4L2_DV_FL_IS_CE_VIDEO instead of V4L2_DV_BT_STD_CEA861

Don't rely on V4L2_DV_BT_STD_CEA861 since that include the
640x480p format, which is an IT format, not CE.
Signed-off-by: default avatarHans Verkuil <hans.verkuil@cisco.com>
Cc: Martin Bugge <marbugge@cisco.com>
Cc: Mats Randgaard <mats.randgaard@cisco.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@osg.samsung.com>
parent 8b44b4e5
...@@ -239,8 +239,8 @@ static void ad9389b_set_IT_content_AVI_InfoFrame(struct v4l2_subdev *sd) ...@@ -239,8 +239,8 @@ static void ad9389b_set_IT_content_AVI_InfoFrame(struct v4l2_subdev *sd)
{ {
struct ad9389b_state *state = get_ad9389b_state(sd); struct ad9389b_state *state = get_ad9389b_state(sd);
if (state->dv_timings.bt.standards & V4L2_DV_BT_STD_CEA861) { if (state->dv_timings.bt.flags & V4L2_DV_FL_IS_CE_VIDEO) {
/* CEA format, not IT */ /* CE format, not IT */
ad9389b_wr_and_or(sd, 0xcd, 0xbf, 0x00); ad9389b_wr_and_or(sd, 0xcd, 0xbf, 0x00);
} else { } else {
/* IT format */ /* IT format */
...@@ -255,11 +255,11 @@ static int ad9389b_set_rgb_quantization_mode(struct v4l2_subdev *sd, struct v4l2 ...@@ -255,11 +255,11 @@ static int ad9389b_set_rgb_quantization_mode(struct v4l2_subdev *sd, struct v4l2
switch (ctrl->val) { switch (ctrl->val) {
case V4L2_DV_RGB_RANGE_AUTO: case V4L2_DV_RGB_RANGE_AUTO:
/* automatic */ /* automatic */
if (state->dv_timings.bt.standards & V4L2_DV_BT_STD_CEA861) { if (state->dv_timings.bt.flags & V4L2_DV_FL_IS_CE_VIDEO) {
/* cea format, RGB limited range (16-235) */ /* CE format, RGB limited range (16-235) */
ad9389b_csc_rgb_full2limit(sd, true); ad9389b_csc_rgb_full2limit(sd, true);
} else { } else {
/* not cea format, RGB full range (0-255) */ /* not CE format, RGB full range (0-255) */
ad9389b_csc_rgb_full2limit(sd, false); ad9389b_csc_rgb_full2limit(sd, false);
} }
break; break;
......
...@@ -312,8 +312,8 @@ static void adv7511_csc_rgb_full2limit(struct v4l2_subdev *sd, bool enable) ...@@ -312,8 +312,8 @@ static void adv7511_csc_rgb_full2limit(struct v4l2_subdev *sd, bool enable)
static void adv7511_set_IT_content_AVI_InfoFrame(struct v4l2_subdev *sd) static void adv7511_set_IT_content_AVI_InfoFrame(struct v4l2_subdev *sd)
{ {
struct adv7511_state *state = get_adv7511_state(sd); struct adv7511_state *state = get_adv7511_state(sd);
if (state->dv_timings.bt.standards & V4L2_DV_BT_STD_CEA861) { if (state->dv_timings.bt.flags & V4L2_DV_FL_IS_CE_VIDEO) {
/* CEA format, not IT */ /* CE format, not IT */
adv7511_wr_and_or(sd, 0x57, 0x7f, 0x00); adv7511_wr_and_or(sd, 0x57, 0x7f, 0x00);
} else { } else {
/* IT format */ /* IT format */
...@@ -331,11 +331,11 @@ static int adv7511_set_rgb_quantization_mode(struct v4l2_subdev *sd, struct v4l2 ...@@ -331,11 +331,11 @@ static int adv7511_set_rgb_quantization_mode(struct v4l2_subdev *sd, struct v4l2
/* automatic */ /* automatic */
struct adv7511_state *state = get_adv7511_state(sd); struct adv7511_state *state = get_adv7511_state(sd);
if (state->dv_timings.bt.standards & V4L2_DV_BT_STD_CEA861) { if (state->dv_timings.bt.flags & V4L2_DV_FL_IS_CE_VIDEO) {
/* cea format, RGB limited range (16-235) */ /* CE format, RGB limited range (16-235) */
adv7511_csc_rgb_full2limit(sd, true); adv7511_csc_rgb_full2limit(sd, true);
} else { } else {
/* not cea format, RGB full range (0-255) */ /* not CE format, RGB full range (0-255) */
adv7511_csc_rgb_full2limit(sd, false); adv7511_csc_rgb_full2limit(sd, false);
} }
} }
......
...@@ -1075,7 +1075,7 @@ static void set_rgb_quantization_range(struct v4l2_subdev *sd) ...@@ -1075,7 +1075,7 @@ static void set_rgb_quantization_range(struct v4l2_subdev *sd)
/* Receiving DVI-D signal /* Receiving DVI-D signal
* ADV7604 selects RGB limited range regardless of * ADV7604 selects RGB limited range regardless of
* input format (CE/IT) in automatic mode */ * input format (CE/IT) in automatic mode */
if (state->timings.bt.standards & V4L2_DV_BT_STD_CEA861) { if (state->timings.bt.flags & V4L2_DV_FL_IS_CE_VIDEO) {
/* RGB limited range (16-235) */ /* RGB limited range (16-235) */
io_write_clr_set(sd, 0x02, 0xf0, 0x00); io_write_clr_set(sd, 0x02, 0xf0, 0x00);
} else { } else {
...@@ -1755,8 +1755,9 @@ static void adv76xx_fill_format(struct adv76xx_state *state, ...@@ -1755,8 +1755,9 @@ static void adv76xx_fill_format(struct adv76xx_state *state,
format->width = state->timings.bt.width; format->width = state->timings.bt.width;
format->height = state->timings.bt.height; format->height = state->timings.bt.height;
format->field = V4L2_FIELD_NONE; format->field = V4L2_FIELD_NONE;
format->colorspace = V4L2_COLORSPACE_SRGB;
if (state->timings.bt.standards & V4L2_DV_BT_STD_CEA861) if (state->timings.bt.flags & V4L2_DV_FL_IS_CE_VIDEO)
format->colorspace = (state->timings.bt.height <= 576) ? format->colorspace = (state->timings.bt.height <= 576) ?
V4L2_COLORSPACE_SMPTE170M : V4L2_COLORSPACE_REC709; V4L2_COLORSPACE_SMPTE170M : V4L2_COLORSPACE_REC709;
} }
......
...@@ -1119,7 +1119,7 @@ static void set_rgb_quantization_range(struct v4l2_subdev *sd) ...@@ -1119,7 +1119,7 @@ static void set_rgb_quantization_range(struct v4l2_subdev *sd)
/* Receiving DVI-D signal /* Receiving DVI-D signal
* ADV7842 selects RGB limited range regardless of * ADV7842 selects RGB limited range regardless of
* input format (CE/IT) in automatic mode */ * input format (CE/IT) in automatic mode */
if (state->timings.bt.standards & V4L2_DV_BT_STD_CEA861) { if (state->timings.bt.flags & V4L2_DV_FL_IS_CE_VIDEO) {
/* RGB limited range (16-235) */ /* RGB limited range (16-235) */
io_write_and_or(sd, 0x02, 0x0f, 0x00); io_write_and_or(sd, 0x02, 0x0f, 0x00);
} else { } else {
...@@ -1901,7 +1901,8 @@ static int adv7842_g_mbus_fmt(struct v4l2_subdev *sd, ...@@ -1901,7 +1901,8 @@ static int adv7842_g_mbus_fmt(struct v4l2_subdev *sd,
return 0; return 0;
} }
if (state->timings.bt.standards & V4L2_DV_BT_STD_CEA861) { fmt->colorspace = V4L2_COLORSPACE_SRGB;
if (state->timings.bt.flags & V4L2_DV_FL_IS_CE_VIDEO) {
fmt->colorspace = (state->timings.bt.height <= 576) ? fmt->colorspace = (state->timings.bt.height <= 576) ?
V4L2_COLORSPACE_SMPTE170M : V4L2_COLORSPACE_REC709; V4L2_COLORSPACE_SMPTE170M : V4L2_COLORSPACE_REC709;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment