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

[media] v4l2: use new V4L2_DV_BT_BLANKING/FRAME defines

Use the new blanking and frame size defines. This also fixed a bug in
these drivers: they assumed that the height for interlaced formats was
the field height, however height is the frame height. So the height
for a field is actually bt->height / 2.
Signed-off-by: default avatarHans Verkuil <hans.verkuil@cisco.com>
Acked-by: default avatarLad, Prabhakar <prabhakar.csengg@gmail.com>
Signed-off-by: default avatarMauro Carvalho Chehab <m.chehab@samsung.com>
parent eacf8f9a
...@@ -1799,19 +1799,15 @@ static int vpif_s_dv_timings(struct file *file, void *priv, ...@@ -1799,19 +1799,15 @@ static int vpif_s_dv_timings(struct file *file, void *priv,
/* Configure video port timings */ /* Configure video port timings */
std_info->eav2sav = bt->hbackporch + bt->hfrontporch + std_info->eav2sav = V4L2_DV_BT_BLANKING_WIDTH(bt) - 8;
bt->hsync - 8;
std_info->sav2eav = bt->width; std_info->sav2eav = bt->width;
std_info->l1 = 1; std_info->l1 = 1;
std_info->l3 = bt->vsync + bt->vbackporch + 1; std_info->l3 = bt->vsync + bt->vbackporch + 1;
std_info->vsize = V4L2_DV_BT_FRAME_HEIGHT(bt);
if (bt->interlaced) { if (bt->interlaced) {
if (bt->il_vbackporch || bt->il_vfrontporch || bt->il_vsync) { if (bt->il_vbackporch || bt->il_vfrontporch || bt->il_vsync) {
std_info->vsize = bt->height * 2 +
bt->vfrontporch + bt->vsync + bt->vbackporch +
bt->il_vfrontporch + bt->il_vsync +
bt->il_vbackporch;
std_info->l5 = std_info->vsize/2 - std_info->l5 = std_info->vsize/2 -
(bt->vfrontporch - 1); (bt->vfrontporch - 1);
std_info->l7 = std_info->vsize/2 + 1; std_info->l7 = std_info->vsize/2 + 1;
...@@ -1825,8 +1821,6 @@ static int vpif_s_dv_timings(struct file *file, void *priv, ...@@ -1825,8 +1821,6 @@ static int vpif_s_dv_timings(struct file *file, void *priv,
return -EINVAL; return -EINVAL;
} }
} else { } else {
std_info->vsize = bt->height + bt->vfrontporch +
bt->vsync + bt->vbackporch;
std_info->l5 = std_info->vsize - (bt->vfrontporch - 1); std_info->l5 = std_info->vsize - (bt->vfrontporch - 1);
} }
strncpy(std_info->name, "Custom timings BT656/1120", VPIF_MAX_NAME); strncpy(std_info->name, "Custom timings BT656/1120", VPIF_MAX_NAME);
......
...@@ -1436,19 +1436,15 @@ static int vpif_s_dv_timings(struct file *file, void *priv, ...@@ -1436,19 +1436,15 @@ static int vpif_s_dv_timings(struct file *file, void *priv,
/* Configure video port timings */ /* Configure video port timings */
std_info->eav2sav = bt->hbackporch + bt->hfrontporch + std_info->eav2sav = V4L2_DV_BT_BLANKING_WIDTH(bt) - 8;
bt->hsync - 8;
std_info->sav2eav = bt->width; std_info->sav2eav = bt->width;
std_info->l1 = 1; std_info->l1 = 1;
std_info->l3 = bt->vsync + bt->vbackporch + 1; std_info->l3 = bt->vsync + bt->vbackporch + 1;
std_info->vsize = V4L2_DV_BT_FRAME_HEIGHT(bt);
if (bt->interlaced) { if (bt->interlaced) {
if (bt->il_vbackporch || bt->il_vfrontporch || bt->il_vsync) { if (bt->il_vbackporch || bt->il_vfrontporch || bt->il_vsync) {
std_info->vsize = bt->height * 2 +
bt->vfrontporch + bt->vsync + bt->vbackporch +
bt->il_vfrontporch + bt->il_vsync +
bt->il_vbackporch;
std_info->l5 = std_info->vsize/2 - std_info->l5 = std_info->vsize/2 -
(bt->vfrontporch - 1); (bt->vfrontporch - 1);
std_info->l7 = std_info->vsize/2 + 1; std_info->l7 = std_info->vsize/2 + 1;
...@@ -1462,8 +1458,6 @@ static int vpif_s_dv_timings(struct file *file, void *priv, ...@@ -1462,8 +1458,6 @@ static int vpif_s_dv_timings(struct file *file, void *priv,
return -EINVAL; return -EINVAL;
} }
} else { } else {
std_info->vsize = bt->height + bt->vfrontporch +
bt->vsync + bt->vbackporch;
std_info->l5 = std_info->vsize - (bt->vfrontporch - 1); std_info->l5 = std_info->vsize - (bt->vfrontporch - 1);
} }
strncpy(std_info->name, "Custom timings BT656/1120", strncpy(std_info->name, "Custom timings BT656/1120",
......
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