Message ID | 20220506153207.19055-1-laurent.pinchart@ideasonboard.com |
---|---|
State | Accepted |
Headers | show |
Series |
|
Related | show |
Hi Laurent, On Fri, May 06, 2022 at 06:32:07PM +0300, Laurent Pinchart 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@ideasonboard.com> > --- > Changes since v1: > > - Fix YVU422M in vpf2pf map Looks good now Reviewed-by: Jacopo Mondi <jacopo@jmondi.org> Thanks j > --- > 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 > -- > Regards, > > Laurent Pinchart >
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@ideasonboard.com> Looks good! Reviewed-by: Umang Jain <umang.jain@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
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),
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@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(+) base-commit: 1e4c4ad5f78ad7abc73854646f6e9902dc3c1925