提交 ba01f673 编写于 作者: H Hans Verkuil 提交者: Mauro Carvalho Chehab

[media] vivid-tpg: add hor/vert downsampling fields

This is step one of supporting horizontal and vertical downsampling.
This just adds support for the h/vdownsampling fields and it increases
the maximum number of planes to 3.

Currently none of the planar formats need horizontal or vertical
downsampling, so this change has no effect at the moment.
Signed-off-by: NHans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: NMauro Carvalho Chehab <mchehab@osg.samsung.com>
上级 4db22041
...@@ -172,6 +172,8 @@ bool tpg_s_fourcc(struct tpg_data *tpg, u32 fourcc) ...@@ -172,6 +172,8 @@ bool tpg_s_fourcc(struct tpg_data *tpg, u32 fourcc)
tpg->planes = 1; tpg->planes = 1;
tpg->buffers = 1; tpg->buffers = 1;
tpg->recalc_colors = true; tpg->recalc_colors = true;
tpg->vdownsampling[0] = 1;
tpg->hdownsampling[0] = 1;
switch (fourcc) { switch (fourcc) {
case V4L2_PIX_FMT_RGB565: case V4L2_PIX_FMT_RGB565:
...@@ -192,6 +194,8 @@ bool tpg_s_fourcc(struct tpg_data *tpg, u32 fourcc) ...@@ -192,6 +194,8 @@ bool tpg_s_fourcc(struct tpg_data *tpg, u32 fourcc)
break; break;
case V4L2_PIX_FMT_NV16M: case V4L2_PIX_FMT_NV16M:
case V4L2_PIX_FMT_NV61M: case V4L2_PIX_FMT_NV61M:
tpg->vdownsampling[1] = 1;
tpg->hdownsampling[1] = 1;
tpg->buffers = 2; tpg->buffers = 2;
tpg->planes = 2; tpg->planes = 2;
/* fall-through */ /* fall-through */
...@@ -273,7 +277,8 @@ void tpg_reset_source(struct tpg_data *tpg, unsigned width, unsigned height, ...@@ -273,7 +277,8 @@ void tpg_reset_source(struct tpg_data *tpg, unsigned width, unsigned height,
tpg->compose.width = width; tpg->compose.width = width;
tpg->compose.height = tpg->buf_height; tpg->compose.height = tpg->buf_height;
for (p = 0; p < tpg->planes; p++) for (p = 0; p < tpg->planes; p++)
tpg->bytesperline[p] = width * tpg->twopixelsize[p] / 2; tpg->bytesperline[p] = (width * tpg->twopixelsize[p]) /
(2 * tpg->hdownsampling[p]);
tpg->recalc_square_border = true; tpg->recalc_square_border = true;
} }
......
...@@ -90,7 +90,7 @@ enum tpg_move_mode { ...@@ -90,7 +90,7 @@ enum tpg_move_mode {
extern const char * const tpg_aspect_strings[]; extern const char * const tpg_aspect_strings[];
#define TPG_MAX_PLANES 2 #define TPG_MAX_PLANES 3
#define TPG_MAX_PAT_LINES 8 #define TPG_MAX_PAT_LINES 8
struct tpg_data { struct tpg_data {
...@@ -140,6 +140,8 @@ struct tpg_data { ...@@ -140,6 +140,8 @@ struct tpg_data {
unsigned real_rgb_range; unsigned real_rgb_range;
unsigned buffers; unsigned buffers;
unsigned planes; unsigned planes;
u8 vdownsampling[TPG_MAX_PLANES];
u8 hdownsampling[TPG_MAX_PLANES];
/* Used to store the colors in native format, either RGB or YUV */ /* Used to store the colors in native format, either RGB or YUV */
u8 colors[TPG_COLOR_MAX][3]; u8 colors[TPG_COLOR_MAX][3];
u8 textfg[TPG_MAX_PLANES][8], textbg[TPG_MAX_PLANES][8]; u8 textfg[TPG_MAX_PLANES][8], textbg[TPG_MAX_PLANES][8];
...@@ -361,10 +363,11 @@ static inline void tpg_s_bytesperline(struct tpg_data *tpg, unsigned plane, unsi ...@@ -361,10 +363,11 @@ static inline void tpg_s_bytesperline(struct tpg_data *tpg, unsigned plane, unsi
for (p = 0; p < tpg->planes; p++) { for (p = 0; p < tpg->planes; p++) {
unsigned plane_w = bpl * tpg->twopixelsize[p] / tpg->twopixelsize[0]; unsigned plane_w = bpl * tpg->twopixelsize[p] / tpg->twopixelsize[0];
tpg->bytesperline[p] = plane_w; tpg->bytesperline[p] = plane_w / tpg->hdownsampling[p];
} }
} }
static inline unsigned tpg_g_line_width(const struct tpg_data *tpg, unsigned plane) static inline unsigned tpg_g_line_width(const struct tpg_data *tpg, unsigned plane)
{ {
unsigned w = 0; unsigned w = 0;
...@@ -375,7 +378,7 @@ static inline unsigned tpg_g_line_width(const struct tpg_data *tpg, unsigned pla ...@@ -375,7 +378,7 @@ static inline unsigned tpg_g_line_width(const struct tpg_data *tpg, unsigned pla
for (p = 0; p < tpg->planes; p++) { for (p = 0; p < tpg->planes; p++) {
unsigned plane_w = tpg_g_bytesperline(tpg, p); unsigned plane_w = tpg_g_bytesperline(tpg, p);
w += plane_w; w += plane_w / tpg->vdownsampling[p];
} }
return w; return w;
} }
...@@ -391,7 +394,8 @@ static inline unsigned tpg_calc_line_width(const struct tpg_data *tpg, ...@@ -391,7 +394,8 @@ static inline unsigned tpg_calc_line_width(const struct tpg_data *tpg,
for (p = 0; p < tpg->planes; p++) { for (p = 0; p < tpg->planes; p++) {
unsigned plane_w = bpl * tpg->twopixelsize[p] / tpg->twopixelsize[0]; unsigned plane_w = bpl * tpg->twopixelsize[p] / tpg->twopixelsize[0];
w += plane_w; plane_w /= tpg->hdownsampling[p];
w += plane_w / tpg->vdownsampling[p];
} }
return w; return w;
} }
...@@ -401,7 +405,8 @@ static inline unsigned tpg_calc_plane_size(const struct tpg_data *tpg, unsigned ...@@ -401,7 +405,8 @@ static inline unsigned tpg_calc_plane_size(const struct tpg_data *tpg, unsigned
if (plane >= tpg->planes) if (plane >= tpg->planes)
return 0; return 0;
return tpg_g_bytesperline(tpg, plane) * tpg->buf_height; return tpg_g_bytesperline(tpg, plane) * tpg->buf_height /
tpg->vdownsampling[plane];
} }
static inline void tpg_s_buf_height(struct tpg_data *tpg, unsigned h) static inline void tpg_s_buf_height(struct tpg_data *tpg, unsigned h)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册