[libcamera-devel] [PATCH v1.1 1/5] libcamera: formats: Add YVU422 pixel format

Umang Jain umang.jain at ideasonboard.com
Fri Jun 3 16:55:35 CEST 2022


Hi Laurent

On 5/6/22 17:32, Laurent Pinchart via libcamera-devel wrote:
> The YVU422 pixel format is defined in both DRM and V4L2. libcamera
> already supports YUV422, add support for the opposite chroma order.
>
> Signed-off-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>


Looks good!

Reviewed-by: Umang Jain <umang.jain at ideasonboard.com>

> ---
> Changes since v1:
>
> - Fix YVU422M in vpf2pf map
> ---
>   src/libcamera/formats.cpp          | 13 +++++++++++++
>   src/libcamera/formats.yaml         |  2 ++
>   src/libcamera/v4l2_pixelformat.cpp |  2 ++
>   3 files changed, 17 insertions(+)
>
> diff --git a/src/libcamera/formats.cpp b/src/libcamera/formats.cpp
> index afcaabc519f7..c5cca37b02c2 100644
> --- a/src/libcamera/formats.cpp
> +++ b/src/libcamera/formats.cpp
> @@ -469,6 +469,19 @@ const std::map<PixelFormat, PixelFormatInfo> pixelFormatInfo{
>   		.pixelsPerGroup = 2,
>   		.planes = {{ { 2, 1 }, { 1, 1 }, { 1, 1 } }},
>   	} },
> +	{ formats::YVU422, {
> +		.name = "YVU422",
> +		.format = formats::YVU422,
> +		.v4l2Formats = {
> +			.single = V4L2PixelFormat(),
> +			.multi = V4L2PixelFormat(V4L2_PIX_FMT_YVU422M),
> +		},
> +		.bitsPerPixel = 16,
> +		.colourEncoding = PixelFormatInfo::ColourEncodingYUV,
> +		.packed = false,
> +		.pixelsPerGroup = 2,
> +		.planes = {{ { 2, 1 }, { 1, 1 }, { 1, 1 } }},
> +	} },
>   
>   	/* Greyscale formats. */
>   	{ formats::R8, {
> diff --git a/src/libcamera/formats.yaml b/src/libcamera/formats.yaml
> index 1f3f043302c3..0b527dbefe32 100644
> --- a/src/libcamera/formats.yaml
> +++ b/src/libcamera/formats.yaml
> @@ -69,6 +69,8 @@ formats:
>         fourcc: DRM_FORMAT_YVU420
>     - YUV422:
>         fourcc: DRM_FORMAT_YUV422
> +  - YVU422:
> +      fourcc: DRM_FORMAT_YVU422
>   
>     - MJPEG:
>         fourcc: DRM_FORMAT_MJPEG
> diff --git a/src/libcamera/v4l2_pixelformat.cpp b/src/libcamera/v4l2_pixelformat.cpp
> index 1dd93baa7a64..40522bf21f6b 100644
> --- a/src/libcamera/v4l2_pixelformat.cpp
> +++ b/src/libcamera/v4l2_pixelformat.cpp
> @@ -113,6 +113,8 @@ const std::map<V4L2PixelFormat, V4L2PixelFormat::Info> vpf2pf{
>   		{ formats::YUV422, "Planar YUV 4:2:2" } },
>   	{ V4L2PixelFormat(V4L2_PIX_FMT_YUV422M),
>   		{ formats::YUV422, "Planar YUV 4:2:2 (N-C)" } },
> +	{ V4L2PixelFormat(V4L2_PIX_FMT_YVU422M),
> +		{ formats::YVU422, "Planar YVU 4:2:2 (N-C)" } },
>   
>   	/* Greyscale formats. */
>   	{ V4L2PixelFormat(V4L2_PIX_FMT_GREY),
>
> base-commit: 1e4c4ad5f78ad7abc73854646f6e9902dc3c1925


More information about the libcamera-devel mailing list