[media] ad9389b/adv7604/ths8200: use new v4l2_print_dv_timings helper
These three drivers all have code to log the dv_timings contents. Replace that code with the new helper function. Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com> Signed-off-by: Mauro Carvalho Chehab <m.chehab@samsung.com>
This commit is contained in:
parent
0216dc2fe6
commit
11d034c8b6
@ -443,20 +443,11 @@ static int ad9389b_log_status(struct v4l2_subdev *sd)
|
|||||||
vic_detect, vic_sent);
|
vic_detect, vic_sent);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (state->dv_timings.type == V4L2_DV_BT_656_1120) {
|
if (state->dv_timings.type == V4L2_DV_BT_656_1120)
|
||||||
struct v4l2_bt_timings *bt = bt = &state->dv_timings.bt;
|
v4l2_print_dv_timings(sd->name, "timings: ",
|
||||||
u32 frame_width = V4L2_DV_BT_FRAME_WIDTH(bt);
|
&state->dv_timings, false);
|
||||||
u32 frame_height = V4L2_DV_BT_FRAME_HEIGHT(bt);
|
else
|
||||||
u32 frame_size = frame_width * frame_height;
|
|
||||||
|
|
||||||
v4l2_info(sd, "timings: %ux%u%s%u (%ux%u). Pix freq. = %u Hz. Polarities = 0x%x\n",
|
|
||||||
bt->width, bt->height, bt->interlaced ? "i" : "p",
|
|
||||||
frame_size > 0 ? (unsigned)bt->pixelclock / frame_size : 0,
|
|
||||||
frame_width, frame_height,
|
|
||||||
(unsigned)bt->pixelclock, bt->polarities);
|
|
||||||
} else {
|
|
||||||
v4l2_info(sd, "no timings set\n");
|
v4l2_info(sd, "no timings set\n");
|
||||||
}
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1051,53 +1051,6 @@ static int adv7604_g_input_status(struct v4l2_subdev *sd, u32 *status)
|
|||||||
|
|
||||||
/* ----------------------------------------------------------------------- */
|
/* ----------------------------------------------------------------------- */
|
||||||
|
|
||||||
static void adv7604_print_timings(struct v4l2_subdev *sd,
|
|
||||||
struct v4l2_dv_timings *timings,
|
|
||||||
const char *txt, bool detailed)
|
|
||||||
{
|
|
||||||
struct v4l2_bt_timings *bt = &timings->bt;
|
|
||||||
u32 htot, vtot;
|
|
||||||
|
|
||||||
if (timings->type != V4L2_DV_BT_656_1120)
|
|
||||||
return;
|
|
||||||
|
|
||||||
htot = htotal(bt);
|
|
||||||
vtot = vtotal(bt);
|
|
||||||
|
|
||||||
v4l2_info(sd, "%s %dx%d%s%d (%dx%d)",
|
|
||||||
txt, bt->width, bt->height, bt->interlaced ? "i" : "p",
|
|
||||||
(htot * vtot) > 0 ? ((u32)bt->pixelclock /
|
|
||||||
(htot * vtot)) : 0,
|
|
||||||
htot, vtot);
|
|
||||||
|
|
||||||
if (!detailed)
|
|
||||||
return;
|
|
||||||
|
|
||||||
v4l2_info(sd, " horizontal: fp = %d, %ssync = %d, bp = %d\n",
|
|
||||||
bt->hfrontporch,
|
|
||||||
(bt->polarities & V4L2_DV_HSYNC_POS_POL) ? "+" : "-",
|
|
||||||
bt->hsync, bt->hbackporch);
|
|
||||||
v4l2_info(sd, " vertical: fp = %d, %ssync = %d, bp = %d\n",
|
|
||||||
bt->vfrontporch,
|
|
||||||
(bt->polarities & V4L2_DV_VSYNC_POS_POL) ? "+" : "-",
|
|
||||||
bt->vsync, bt->vbackporch);
|
|
||||||
v4l2_info(sd, " pixelclock: %lld\n", bt->pixelclock);
|
|
||||||
v4l2_info(sd, " flags (0x%x):%s%s%s%s\n", bt->flags,
|
|
||||||
(bt->flags & V4L2_DV_FL_REDUCED_BLANKING) ?
|
|
||||||
" Reduced blanking," : "",
|
|
||||||
(bt->flags & V4L2_DV_FL_CAN_REDUCE_FPS) ?
|
|
||||||
" Can reduce FPS," : "",
|
|
||||||
(bt->flags & V4L2_DV_FL_REDUCED_FPS) ?
|
|
||||||
" Reduced FPS," : "",
|
|
||||||
(bt->flags & V4L2_DV_FL_HALF_LINE) ?
|
|
||||||
" Half line," : "");
|
|
||||||
v4l2_info(sd, " standards (0x%x):%s%s%s%s\n", bt->standards,
|
|
||||||
(bt->standards & V4L2_DV_BT_STD_CEA861) ? " CEA," : "",
|
|
||||||
(bt->standards & V4L2_DV_BT_STD_DMT) ? " DMT," : "",
|
|
||||||
(bt->standards & V4L2_DV_BT_STD_CVT) ? " CVT" : "",
|
|
||||||
(bt->standards & V4L2_DV_BT_STD_GTF) ? " GTF" : "");
|
|
||||||
}
|
|
||||||
|
|
||||||
struct stdi_readback {
|
struct stdi_readback {
|
||||||
u16 bl, lcf, lcvs;
|
u16 bl, lcf, lcvs;
|
||||||
u8 hs_pol, vs_pol;
|
u8 hs_pol, vs_pol;
|
||||||
@ -1360,8 +1313,8 @@ found:
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (debug > 1)
|
if (debug > 1)
|
||||||
adv7604_print_timings(sd, timings,
|
v4l2_print_dv_timings(sd->name, "adv7604_query_dv_timings: ",
|
||||||
"adv7604_query_dv_timings:", true);
|
timings, true);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -1403,8 +1356,8 @@ static int adv7604_s_dv_timings(struct v4l2_subdev *sd,
|
|||||||
|
|
||||||
|
|
||||||
if (debug > 1)
|
if (debug > 1)
|
||||||
adv7604_print_timings(sd, timings,
|
v4l2_print_dv_timings(sd->name, "adv7604_s_dv_timings: ",
|
||||||
"adv7604_s_dv_timings:", true);
|
timings, true);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1770,8 +1723,10 @@ static int adv7604_log_status(struct v4l2_subdev *sd)
|
|||||||
if (adv7604_query_dv_timings(sd, &timings))
|
if (adv7604_query_dv_timings(sd, &timings))
|
||||||
v4l2_info(sd, "No video detected\n");
|
v4l2_info(sd, "No video detected\n");
|
||||||
else
|
else
|
||||||
adv7604_print_timings(sd, &timings, "Detected format:", true);
|
v4l2_print_dv_timings(sd->name, "Detected format: ",
|
||||||
adv7604_print_timings(sd, &state->timings, "Configured format:", true);
|
&timings, true);
|
||||||
|
v4l2_print_dv_timings(sd->name, "Configured format: ",
|
||||||
|
&state->timings, true);
|
||||||
|
|
||||||
if (no_signal(sd))
|
if (no_signal(sd))
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -133,39 +133,6 @@ static int ths8200_s_register(struct v4l2_subdev *sd,
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static void ths8200_print_timings(struct v4l2_subdev *sd,
|
|
||||||
struct v4l2_dv_timings *timings,
|
|
||||||
const char *txt, bool detailed)
|
|
||||||
{
|
|
||||||
struct v4l2_bt_timings *bt = &timings->bt;
|
|
||||||
u32 htot, vtot;
|
|
||||||
|
|
||||||
if (timings->type != V4L2_DV_BT_656_1120)
|
|
||||||
return;
|
|
||||||
|
|
||||||
htot = htotal(bt);
|
|
||||||
vtot = vtotal(bt);
|
|
||||||
|
|
||||||
v4l2_info(sd, "%s %dx%d%s%d (%dx%d)",
|
|
||||||
txt, bt->width, bt->height, bt->interlaced ? "i" : "p",
|
|
||||||
(htot * vtot) > 0 ? ((u32)bt->pixelclock / (htot * vtot)) : 0,
|
|
||||||
htot, vtot);
|
|
||||||
|
|
||||||
if (detailed) {
|
|
||||||
v4l2_info(sd, " horizontal: fp = %d, %ssync = %d, bp = %d\n",
|
|
||||||
bt->hfrontporch,
|
|
||||||
(bt->polarities & V4L2_DV_HSYNC_POS_POL) ? "+" : "-",
|
|
||||||
bt->hsync, bt->hbackporch);
|
|
||||||
v4l2_info(sd, " vertical: fp = %d, %ssync = %d, bp = %d\n",
|
|
||||||
bt->vfrontporch,
|
|
||||||
(bt->polarities & V4L2_DV_VSYNC_POS_POL) ? "+" : "-",
|
|
||||||
bt->vsync, bt->vbackporch);
|
|
||||||
v4l2_info(sd,
|
|
||||||
" pixelclock: %lld, flags: 0x%x, standards: 0x%x\n",
|
|
||||||
bt->pixelclock, bt->flags, bt->standards);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static int ths8200_log_status(struct v4l2_subdev *sd)
|
static int ths8200_log_status(struct v4l2_subdev *sd)
|
||||||
{
|
{
|
||||||
struct ths8200_state *state = to_state(sd);
|
struct ths8200_state *state = to_state(sd);
|
||||||
@ -182,9 +149,8 @@ static int ths8200_log_status(struct v4l2_subdev *sd)
|
|||||||
ths8200_read(sd, THS8200_DTG2_PIXEL_CNT_LSB),
|
ths8200_read(sd, THS8200_DTG2_PIXEL_CNT_LSB),
|
||||||
(ths8200_read(sd, THS8200_DTG2_LINE_CNT_MSB) & 0x07) * 256 +
|
(ths8200_read(sd, THS8200_DTG2_LINE_CNT_MSB) & 0x07) * 256 +
|
||||||
ths8200_read(sd, THS8200_DTG2_LINE_CNT_LSB));
|
ths8200_read(sd, THS8200_DTG2_LINE_CNT_LSB));
|
||||||
ths8200_print_timings(sd, &state->dv_timings,
|
v4l2_print_dv_timings(sd->name, "Configured format:",
|
||||||
"Configured format:", true);
|
&state->dv_timings, true);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user