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

[media] vivid-tpg: move pattern-related fields to struct tpg_draw_params

Add a new function that fills in pattern-related fields in struct
tpg_draw_params.
Signed-off-by: default avatarHans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@osg.samsung.com>
parent 5e729393
...@@ -1543,13 +1543,26 @@ struct tpg_draw_params { ...@@ -1543,13 +1543,26 @@ struct tpg_draw_params {
unsigned right_pillar_start; unsigned right_pillar_start;
}; };
static void tpg_fill_params_pattern(const struct tpg_data *tpg, unsigned p,
struct tpg_draw_params *params)
{
params->mv_hor_old =
tpg_hscale_div(tpg, p, tpg->mv_hor_count % tpg->src_width);
params->mv_hor_new =
tpg_hscale_div(tpg, p, (tpg->mv_hor_count + tpg->mv_hor_step) %
tpg->src_width);
params->mv_vert_old = tpg->mv_vert_count % tpg->src_height;
params->mv_vert_new =
(tpg->mv_vert_count + tpg->mv_vert_step) % tpg->src_height;
}
void tpg_fill_plane_buffer(struct tpg_data *tpg, v4l2_std_id std, unsigned p, u8 *vbuf) void tpg_fill_plane_buffer(struct tpg_data *tpg, v4l2_std_id std, unsigned p, u8 *vbuf)
{ {
struct tpg_draw_params params; struct tpg_draw_params params;
unsigned mv_hor_old = tpg->mv_hor_count % tpg->src_width; unsigned mv_hor_old;
unsigned mv_hor_new = (tpg->mv_hor_count + tpg->mv_hor_step) % tpg->src_width; unsigned mv_hor_new;
unsigned mv_vert_old = tpg->mv_vert_count % tpg->src_height; unsigned mv_vert_old;
unsigned mv_vert_new = (tpg->mv_vert_count + tpg->mv_vert_step) % tpg->src_height; unsigned mv_vert_new;
unsigned wss_width; unsigned wss_width;
unsigned f; unsigned f;
int h; int h;
...@@ -1578,12 +1591,17 @@ void tpg_fill_plane_buffer(struct tpg_data *tpg, v4l2_std_id std, unsigned p, u8 ...@@ -1578,12 +1591,17 @@ void tpg_fill_plane_buffer(struct tpg_data *tpg, v4l2_std_id std, unsigned p, u8
params.stride = tpg->bytesperline[p]; params.stride = tpg->bytesperline[p];
params.hmax = (tpg->compose.height * tpg->perc_fill) / 100; params.hmax = (tpg->compose.height * tpg->perc_fill) / 100;
tpg_fill_params_pattern(tpg, p, &params);
mv_hor_old = params.mv_hor_old;
mv_hor_new = params.mv_hor_new;
mv_vert_old = params.mv_vert_old;
mv_vert_new = params.mv_vert_new;
twopixsize = params.twopixsize; twopixsize = params.twopixsize;
img_width = params.img_width; img_width = params.img_width;
stride = params.stride; stride = params.stride;
mv_hor_old = tpg_hscale_div(tpg, p, mv_hor_old);
mv_hor_new = tpg_hscale_div(tpg, p, mv_hor_new);
wss_width = tpg->crop.left < tpg->src_width / 2 ? wss_width = tpg->crop.left < tpg->src_width / 2 ?
tpg->src_width / 2 - tpg->crop.left : 0; tpg->src_width / 2 - tpg->crop.left : 0;
if (wss_width > tpg->crop.width) if (wss_width > tpg->crop.width)
......
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