diff options
author | Steve Longerbeam <slongerbeam@gmail.com> | 2019-01-09 13:30:06 -0500 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab+samsung@kernel.org> | 2019-01-16 14:12:20 -0500 |
commit | 9b5c8d5ffb20cc4f4b1476cb1ad57e0f9b934788 (patch) | |
tree | eaeabe3d984667fe020a926f8f7e33d8b520127d /include/video | |
parent | fc8c723852380b0f4349bb06cf553a6bba47462e (diff) |
media: gpu: ipu-v3: Add planar support to interlaced scan
To support interlaced scan with planar formats, cpmem SLUV must
be programmed with the correct chroma line stride. For full and
partial planar 4:2:2 (YUV422P, NV16), chroma line stride must
be doubled. For full and partial planar 4:2:0 (YUV420, YVU420, NV12),
chroma line stride must _not_ be doubled, since a single chroma line
is shared by two luma lines.
Signed-off-by: Steve Longerbeam <slongerbeam@gmail.com>
Reviewed-by: Philipp Zabel <p.zabel@pengutronix.de>
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: Mauro Carvalho Chehab <mchehab+samsung@kernel.org>
Diffstat (limited to 'include/video')
-rw-r--r-- | include/video/imx-ipu-v3.h | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/include/video/imx-ipu-v3.h b/include/video/imx-ipu-v3.h index bbc8481f567d..c887f4bee5f8 100644 --- a/include/video/imx-ipu-v3.h +++ b/include/video/imx-ipu-v3.h | |||
@@ -258,7 +258,8 @@ void ipu_cpmem_set_stride(struct ipuv3_channel *ch, int stride); | |||
258 | void ipu_cpmem_set_high_priority(struct ipuv3_channel *ch); | 258 | void ipu_cpmem_set_high_priority(struct ipuv3_channel *ch); |
259 | void ipu_cpmem_set_buffer(struct ipuv3_channel *ch, int bufnum, dma_addr_t buf); | 259 | void ipu_cpmem_set_buffer(struct ipuv3_channel *ch, int bufnum, dma_addr_t buf); |
260 | void ipu_cpmem_set_uv_offset(struct ipuv3_channel *ch, u32 u_off, u32 v_off); | 260 | void ipu_cpmem_set_uv_offset(struct ipuv3_channel *ch, u32 u_off, u32 v_off); |
261 | void ipu_cpmem_interlaced_scan(struct ipuv3_channel *ch, int stride); | 261 | void ipu_cpmem_interlaced_scan(struct ipuv3_channel *ch, int stride, |
262 | u32 pixelformat); | ||
262 | void ipu_cpmem_set_axi_id(struct ipuv3_channel *ch, u32 id); | 263 | void ipu_cpmem_set_axi_id(struct ipuv3_channel *ch, u32 id); |
263 | int ipu_cpmem_get_burstsize(struct ipuv3_channel *ch); | 264 | int ipu_cpmem_get_burstsize(struct ipuv3_channel *ch); |
264 | void ipu_cpmem_set_burstsize(struct ipuv3_channel *ch, int burstsize); | 265 | void ipu_cpmem_set_burstsize(struct ipuv3_channel *ch, int burstsize); |