[{"id":28776,"web_url":"https://patchwork.libcamera.org/comment/28776/","msgid":"<5xfnqqx6jenwc3oao3gfpuypvn45sfkqd7euxdxz4topaynl5n@bk6oyv3nubrf>","date":"2024-02-28T08:27:27","subject":"Re: [PATCH 2/9] libcamera: v4l2_subdevice: Add code member to\n\tMediaBusFormatInfo","submitter":{"id":143,"url":"https://patchwork.libcamera.org/api/people/143/","name":"Jacopo Mondi","email":"jacopo.mondi@ideasonboard.com"},"content":"Hi Laurent\n\nOn Tue, Feb 27, 2024 at 04:09:46PM +0200, Laurent Pinchart wrote:\n> To prepare for exposing the MediaBusFormatInfo structure as an internal\n> API, add a code member to the structure to store the media bus code.\n> This makes MediaBusFormatInfo usable standalone, without having to\n> externally associate the code related to the info.\n>\n> The entries in the mediaBusFormatInfo map are becoming too long, so\n> split them on multiple lines.\n>\n> While at it, swap the order of the members to match the PixelFormatInfo\n> class for consistency.\n>\n> Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>\n> ---\n>  src/libcamera/v4l2_subdevice.cpp | 554 ++++++++++++++++++++++++++-----\n>  1 file changed, 473 insertions(+), 81 deletions(-)\n>\n> diff --git a/src/libcamera/v4l2_subdevice.cpp b/src/libcamera/v4l2_subdevice.cpp\n> index 6c1df7812f07..a74b8362b6d1 100644\n> --- a/src/libcamera/v4l2_subdevice.cpp\n> +++ b/src/libcamera/v4l2_subdevice.cpp\n> @@ -41,13 +41,15 @@ namespace {\n>  /*\n>   * \\struct MediaBusFormatInfo\n>   * \\brief Information about media bus formats\n> - * \\param bitsPerPixel Bits per pixel\n>   * \\param name Name of MBUS format\n> + * \\param code The media bus format code\n> + * \\param bitsPerPixel Bits per pixel\n>   * \\param colourEncoding Type of colour encoding\n>   */\n>  struct MediaBusFormatInfo {\n> -\tunsigned int bitsPerPixel;\n>  \tconst char *name;\n> +\tuint32_t code;\n> +\tunsigned int bitsPerPixel;\n>  \tPixelFormatInfo::ColourEncoding colourEncoding;\n>  };\n>\n> @@ -56,87 +58,477 @@ struct MediaBusFormatInfo {\n>   * \\brief A map that associates MediaBusFormatInfo struct to V4L2 media\n>   * bus codes\n>   */\n> -const std::map<uint32_t, MediaBusFormatInfo> mediaBusFormatInfo = {\n> +const std::map<uint32_t, MediaBusFormatInfo> mediaBusFormatInfo{\n\nDoes this make any practical difference ? I guess the compiler is\nsmart enough to avoid constructing a map and then copying it ?\n\n\n>  \t/* This table is sorted to match the order in linux/media-bus-format.h */\n> -\t{ MEDIA_BUS_FMT_RGB444_2X8_PADHI_BE, { 16, \"RGB444_2X8_PADHI_BE\", PixelFormatInfo::ColourEncodingRGB } },\n> -\t{ MEDIA_BUS_FMT_RGB444_2X8_PADHI_LE, { 16, \"RGB444_2X8_PADHI_LE\", PixelFormatInfo::ColourEncodingRGB } },\n> -\t{ MEDIA_BUS_FMT_RGB555_2X8_PADHI_BE, { 16, \"RGB555_2X8_PADHI_BE\", PixelFormatInfo::ColourEncodingRGB } },\n> -\t{ MEDIA_BUS_FMT_RGB555_2X8_PADHI_LE, { 16, \"RGB555_2X8_PADHI_LE\", PixelFormatInfo::ColourEncodingRGB } },\n> -\t{ MEDIA_BUS_FMT_RGB565_1X16, { 16, \"RGB565_1X16\", PixelFormatInfo::ColourEncodingRGB } },\n> -\t{ MEDIA_BUS_FMT_BGR565_2X8_BE, { 16, \"BGR565_2X8_BE\", PixelFormatInfo::ColourEncodingRGB } },\n> -\t{ MEDIA_BUS_FMT_BGR565_2X8_LE, { 16, \"BGR565_2X8_LE\", PixelFormatInfo::ColourEncodingRGB } },\n> -\t{ MEDIA_BUS_FMT_RGB565_2X8_BE, { 16, \"RGB565_2X8_BE\", PixelFormatInfo::ColourEncodingRGB } },\n> -\t{ MEDIA_BUS_FMT_RGB565_2X8_LE, { 16, \"RGB565_2X8_LE\", PixelFormatInfo::ColourEncodingRGB } },\n> -\t{ MEDIA_BUS_FMT_RGB666_1X18, { 18, \"RGB666_1X18\", PixelFormatInfo::ColourEncodingRGB } },\n> -\t{ MEDIA_BUS_FMT_BGR888_1X24, { 24, \"BGR888_1X24\", PixelFormatInfo::ColourEncodingRGB } },\n> -\t{ MEDIA_BUS_FMT_RGB888_1X24, { 24, \"RGB888_1X24\", PixelFormatInfo::ColourEncodingRGB } },\n> -\t{ MEDIA_BUS_FMT_RGB888_2X12_BE, { 24, \"RGB888_2X12_BE\", PixelFormatInfo::ColourEncodingRGB } },\n> -\t{ MEDIA_BUS_FMT_RGB888_2X12_LE, { 24, \"RGB888_2X12_LE\", PixelFormatInfo::ColourEncodingRGB } },\n> -\t{ MEDIA_BUS_FMT_ARGB8888_1X32, { 32, \"ARGB8888_1X32\", PixelFormatInfo::ColourEncodingRGB } },\n> -\t{ MEDIA_BUS_FMT_Y8_1X8, { 8, \"Y8_1X8\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_UV8_1X8, { 8, \"UV8_1X8\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_UYVY8_1_5X8, { 12, \"UYVY8_1_5X8\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_VYUY8_1_5X8, { 12, \"VYUY8_1_5X8\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_YUYV8_1_5X8, { 12, \"YUYV8_1_5X8\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_YVYU8_1_5X8, { 12, \"YVYU8_1_5X8\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_UYVY8_2X8, { 16, \"UYVY8_2X8\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_VYUY8_2X8, { 16, \"VYUY8_2X8\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_YUYV8_2X8, { 16, \"YUYV8_2X8\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_YVYU8_2X8, { 16, \"YVYU8_2X8\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_Y10_1X10, { 10, \"Y10_1X10\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_UYVY10_2X10, { 20, \"UYVY10_2X10\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_VYUY10_2X10, { 20, \"VYUY10_2X10\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_YUYV10_2X10, { 20, \"YUYV10_2X10\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_YVYU10_2X10, { 20, \"YVYU10_2X10\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_Y12_1X12, { 12, \"Y12_1X12\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_Y16_1X16, { 16, \"Y16_1X16\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_UYVY8_1X16, { 16, \"UYVY8_1X16\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_VYUY8_1X16, { 16, \"VYUY8_1X16\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_YUYV8_1X16, { 16, \"YUYV8_1X16\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_YVYU8_1X16, { 16, \"YVYU8_1X16\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_YDYUYDYV8_1X16, { 16, \"YDYUYDYV8_1X16\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_UYVY10_1X20, { 20, \"UYVY10_1X20\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_VYUY10_1X20, { 20, \"VYUY10_1X20\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_YUYV10_1X20, { 20, \"YUYV10_1X20\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_YVYU10_1X20, { 20, \"YVYU10_1X20\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_YUV8_1X24, { 24, \"YUV8_1X24\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_YUV10_1X30, { 30, \"YUV10_1X30\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_AYUV8_1X32, { 32, \"AYUV8_1X32\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_UYVY12_2X12, { 24, \"UYVY12_2X12\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_VYUY12_2X12, { 24, \"VYUY12_2X12\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_YUYV12_2X12, { 24, \"YUYV12_2X12\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_YVYU12_2X12, { 24, \"YVYU12_2X12\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_UYVY12_1X24, { 24, \"UYVY12_1X24\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_VYUY12_1X24, { 24, \"VYUY12_1X24\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_YUYV12_1X24, { 24, \"YUYV12_1X24\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_YVYU12_1X24, { 24, \"YVYU12_1X24\", PixelFormatInfo::ColourEncodingYUV } },\n> -\t{ MEDIA_BUS_FMT_SBGGR8_1X8, { 8, \"SBGGR8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SGBRG8_1X8, { 8, \"SGBRG8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SGRBG8_1X8, { 8, \"SGRBG8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SRGGB8_1X8, { 8, \"SRGGB8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SBGGR10_ALAW8_1X8, { 8, \"SBGGR10_ALAW8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SGBRG10_ALAW8_1X8, { 8, \"SGBRG10_ALAW8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SGRBG10_ALAW8_1X8, { 8, \"SGRBG10_ALAW8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SRGGB10_ALAW8_1X8, { 8, \"SRGGB10_ALAW8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SBGGR10_DPCM8_1X8, { 8, \"SBGGR10_DPCM8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SGBRG10_DPCM8_1X8, { 8, \"SGBRG10_DPCM8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SGRBG10_DPCM8_1X8, { 8, \"SGRBG10_DPCM8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SRGGB10_DPCM8_1X8, { 8, \"SRGGB10_DPCM8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SBGGR10_2X8_PADHI_BE, { 16, \"SBGGR10_2X8_PADHI_BE\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SBGGR10_2X8_PADHI_LE, { 16, \"SBGGR10_2X8_PADHI_LE\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SBGGR10_2X8_PADLO_BE, { 16, \"SBGGR10_2X8_PADLO_BE\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SBGGR10_2X8_PADLO_LE, { 16, \"SBGGR10_2X8_PADLO_LE\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SBGGR10_1X10, { 10, \"SBGGR10_1X10\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SGBRG10_1X10, { 10, \"SGBRG10_1X10\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SGRBG10_1X10, { 10, \"SGRBG10_1X10\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SRGGB10_1X10, { 10, \"SRGGB10_1X10\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SBGGR12_1X12, { 12, \"SBGGR12_1X12\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SGBRG12_1X12, { 12, \"SGBRG12_1X12\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SGRBG12_1X12, { 12, \"SGRBG12_1X12\", PixelFormatInfo::ColourEncodingRAW } },\n> -\t{ MEDIA_BUS_FMT_SRGGB12_1X12, { 12, \"SRGGB12_1X12\", PixelFormatInfo::ColourEncodingRAW } },\n> +\t{ MEDIA_BUS_FMT_RGB444_2X8_PADHI_BE, {\n> +\t\t.name = \"RGB444_2X8_PADHI_BE\",\n> +\t\t.code = MEDIA_BUS_FMT_RGB444_2X8_PADHI_BE,\n\nSo we now have the map indexed by media bus code, and the media bus\ninfo contains the code.\n\nI wonder if we need a map, or we can just provide an helper to search\nthe media bus info entries by code, to avoid duplicating the\ninformation (it shouldn't be hard to keep them in sync, so it's maybe\nnot a big deal).\n\nThis apart\nReviewed-by: Jacopo Mondi <jacopo.mondi@ideasonboard.com>\n\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_RGB444_2X8_PADHI_LE, {\n> +\t\t.name = \"RGB444_2X8_PADHI_LE\",\n> +\t\t.code = MEDIA_BUS_FMT_RGB444_2X8_PADHI_LE,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_RGB555_2X8_PADHI_BE, {\n> +\t\t.name = \"RGB555_2X8_PADHI_BE\",\n> +\t\t.code = MEDIA_BUS_FMT_RGB555_2X8_PADHI_BE,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_RGB555_2X8_PADHI_LE, {\n> +\t\t.name = \"RGB555_2X8_PADHI_LE\",\n> +\t\t.code = MEDIA_BUS_FMT_RGB555_2X8_PADHI_LE,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_RGB565_1X16, {\n> +\t\t.name = \"RGB565_1X16\",\n> +\t\t.code = MEDIA_BUS_FMT_RGB565_1X16,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_BGR565_2X8_BE, {\n> +\t\t.name = \"BGR565_2X8_BE\",\n> +\t\t.code = MEDIA_BUS_FMT_BGR565_2X8_BE,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_BGR565_2X8_LE, {\n> +\t\t.name = \"BGR565_2X8_LE\",\n> +\t\t.code = MEDIA_BUS_FMT_BGR565_2X8_LE,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_RGB565_2X8_BE, {\n> +\t\t.name = \"RGB565_2X8_BE\",\n> +\t\t.code = MEDIA_BUS_FMT_RGB565_2X8_BE,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_RGB565_2X8_LE, {\n> +\t\t.name = \"RGB565_2X8_LE\",\n> +\t\t.code = MEDIA_BUS_FMT_RGB565_2X8_LE,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_RGB666_1X18, {\n> +\t\t.name = \"RGB666_1X18\",\n> +\t\t.code = MEDIA_BUS_FMT_RGB666_1X18,\n> +\t\t.bitsPerPixel = 18,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_BGR888_1X24, {\n> +\t\t.name = \"BGR888_1X24\",\n> +\t\t.code = MEDIA_BUS_FMT_BGR888_1X24,\n> +\t\t.bitsPerPixel = 24,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_RGB888_1X24, {\n> +\t\t.name = \"RGB888_1X24\",\n> +\t\t.code = MEDIA_BUS_FMT_RGB888_1X24,\n> +\t\t.bitsPerPixel = 24,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_RGB888_2X12_BE, {\n> +\t\t.name = \"RGB888_2X12_BE\",\n> +\t\t.code = MEDIA_BUS_FMT_RGB888_2X12_BE,\n> +\t\t.bitsPerPixel = 24,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_RGB888_2X12_LE, {\n> +\t\t.name = \"RGB888_2X12_LE\",\n> +\t\t.code = MEDIA_BUS_FMT_RGB888_2X12_LE,\n> +\t\t.bitsPerPixel = 24,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_ARGB8888_1X32, {\n> +\t\t.name = \"ARGB8888_1X32\",\n> +\t\t.code = MEDIA_BUS_FMT_ARGB8888_1X32,\n> +\t\t.bitsPerPixel = 32,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_Y8_1X8, {\n> +\t\t.name = \"Y8_1X8\",\n> +\t\t.code = MEDIA_BUS_FMT_Y8_1X8,\n> +\t\t.bitsPerPixel = 8,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_UV8_1X8, {\n> +\t\t.name = \"UV8_1X8\",\n> +\t\t.code = MEDIA_BUS_FMT_UV8_1X8,\n> +\t\t.bitsPerPixel = 8,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_UYVY8_1_5X8, {\n> +\t\t.name = \"UYVY8_1_5X8\",\n> +\t\t.code = MEDIA_BUS_FMT_UYVY8_1_5X8,\n> +\t\t.bitsPerPixel = 12,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_VYUY8_1_5X8, {\n> +\t\t.name = \"VYUY8_1_5X8\",\n> +\t\t.code = MEDIA_BUS_FMT_VYUY8_1_5X8,\n> +\t\t.bitsPerPixel = 12,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_YUYV8_1_5X8, {\n> +\t\t.name = \"YUYV8_1_5X8\",\n> +\t\t.code = MEDIA_BUS_FMT_YUYV8_1_5X8,\n> +\t\t.bitsPerPixel = 12,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_YVYU8_1_5X8, {\n> +\t\t.name = \"YVYU8_1_5X8\",\n> +\t\t.code = MEDIA_BUS_FMT_YVYU8_1_5X8,\n> +\t\t.bitsPerPixel = 12,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_UYVY8_2X8, {\n> +\t\t.name = \"UYVY8_2X8\",\n> +\t\t.code = MEDIA_BUS_FMT_UYVY8_2X8,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_VYUY8_2X8, {\n> +\t\t.name = \"VYUY8_2X8\",\n> +\t\t.code = MEDIA_BUS_FMT_VYUY8_2X8,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_YUYV8_2X8, {\n> +\t\t.name = \"YUYV8_2X8\",\n> +\t\t.code = MEDIA_BUS_FMT_YUYV8_2X8,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_YVYU8_2X8, {\n> +\t\t.name = \"YVYU8_2X8\",\n> +\t\t.code = MEDIA_BUS_FMT_YVYU8_2X8,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_Y10_1X10, {\n> +\t\t.name = \"Y10_1X10\",\n> +\t\t.code = MEDIA_BUS_FMT_Y10_1X10,\n> +\t\t.bitsPerPixel = 10,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_UYVY10_2X10, {\n> +\t\t.name = \"UYVY10_2X10\",\n> +\t\t.code = MEDIA_BUS_FMT_UYVY10_2X10,\n> +\t\t.bitsPerPixel = 20,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_VYUY10_2X10, {\n> +\t\t.name = \"VYUY10_2X10\",\n> +\t\t.code = MEDIA_BUS_FMT_VYUY10_2X10,\n> +\t\t.bitsPerPixel = 20,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_YUYV10_2X10, {\n> +\t\t.name = \"YUYV10_2X10\",\n> +\t\t.code = MEDIA_BUS_FMT_YUYV10_2X10,\n> +\t\t.bitsPerPixel = 20,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_YVYU10_2X10, {\n> +\t\t.name = \"YVYU10_2X10\",\n> +\t\t.code = MEDIA_BUS_FMT_YVYU10_2X10,\n> +\t\t.bitsPerPixel = 20,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_Y12_1X12, {\n> +\t\t.name = \"Y12_1X12\",\n> +\t\t.code = MEDIA_BUS_FMT_Y12_1X12,\n> +\t\t.bitsPerPixel = 12,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_Y16_1X16, {\n> +\t\t.name = \"Y16_1X16\",\n> +\t\t.code = MEDIA_BUS_FMT_Y16_1X16,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_UYVY8_1X16, {\n> +\t\t.name = \"UYVY8_1X16\",\n> +\t\t.code = MEDIA_BUS_FMT_UYVY8_1X16,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_VYUY8_1X16, {\n> +\t\t.name = \"VYUY8_1X16\",\n> +\t\t.code = MEDIA_BUS_FMT_VYUY8_1X16,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_YUYV8_1X16, {\n> +\t\t.name = \"YUYV8_1X16\",\n> +\t\t.code = MEDIA_BUS_FMT_YUYV8_1X16,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_YVYU8_1X16, {\n> +\t\t.name = \"YVYU8_1X16\",\n> +\t\t.code = MEDIA_BUS_FMT_YVYU8_1X16,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_YDYUYDYV8_1X16, {\n> +\t\t.name = \"YDYUYDYV8_1X16\",\n> +\t\t.code = MEDIA_BUS_FMT_YDYUYDYV8_1X16,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_UYVY10_1X20, {\n> +\t\t.name = \"UYVY10_1X20\",\n> +\t\t.code = MEDIA_BUS_FMT_UYVY10_1X20,\n> +\t\t.bitsPerPixel = 20,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_VYUY10_1X20, {\n> +\t\t.name = \"VYUY10_1X20\",\n> +\t\t.code = MEDIA_BUS_FMT_VYUY10_1X20,\n> +\t\t.bitsPerPixel = 20,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_YUYV10_1X20, {\n> +\t\t.name = \"YUYV10_1X20\",\n> +\t\t.code = MEDIA_BUS_FMT_YUYV10_1X20,\n> +\t\t.bitsPerPixel = 20,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_YVYU10_1X20, {\n> +\t\t.name = \"YVYU10_1X20\",\n> +\t\t.code = MEDIA_BUS_FMT_YVYU10_1X20,\n> +\t\t.bitsPerPixel = 20,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_YUV8_1X24, {\n> +\t\t.name = \"YUV8_1X24\",\n> +\t\t.code = MEDIA_BUS_FMT_YUV8_1X24,\n> +\t\t.bitsPerPixel = 24,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_YUV10_1X30, {\n> +\t\t.name = \"YUV10_1X30\",\n> +\t\t.code = MEDIA_BUS_FMT_YUV10_1X30,\n> +\t\t.bitsPerPixel = 30,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_AYUV8_1X32, {\n> +\t\t.name = \"AYUV8_1X32\",\n> +\t\t.code = MEDIA_BUS_FMT_AYUV8_1X32,\n> +\t\t.bitsPerPixel = 32,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_UYVY12_2X12, {\n> +\t\t.name = \"UYVY12_2X12\",\n> +\t\t.code = MEDIA_BUS_FMT_UYVY12_2X12,\n> +\t\t.bitsPerPixel = 24,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_VYUY12_2X12, {\n> +\t\t.name = \"VYUY12_2X12\",\n> +\t\t.code = MEDIA_BUS_FMT_VYUY12_2X12,\n> +\t\t.bitsPerPixel = 24,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_YUYV12_2X12, {\n> +\t\t.name = \"YUYV12_2X12\",\n> +\t\t.code = MEDIA_BUS_FMT_YUYV12_2X12,\n> +\t\t.bitsPerPixel = 24,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_YVYU12_2X12, {\n> +\t\t.name = \"YVYU12_2X12\",\n> +\t\t.code = MEDIA_BUS_FMT_YVYU12_2X12,\n> +\t\t.bitsPerPixel = 24,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_UYVY12_1X24, {\n> +\t\t.name = \"UYVY12_1X24\",\n> +\t\t.code = MEDIA_BUS_FMT_UYVY12_1X24,\n> +\t\t.bitsPerPixel = 24,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_VYUY12_1X24, {\n> +\t\t.name = \"VYUY12_1X24\",\n> +\t\t.code = MEDIA_BUS_FMT_VYUY12_1X24,\n> +\t\t.bitsPerPixel = 24,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_YUYV12_1X24, {\n> +\t\t.name = \"YUYV12_1X24\",\n> +\t\t.code = MEDIA_BUS_FMT_YUYV12_1X24,\n> +\t\t.bitsPerPixel = 24,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_YVYU12_1X24, {\n> +\t\t.name = \"YVYU12_1X24\",\n> +\t\t.code = MEDIA_BUS_FMT_YVYU12_1X24,\n> +\t\t.bitsPerPixel = 24,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SBGGR8_1X8, {\n> +\t\t.name = \"SBGGR8_1X8\",\n> +\t\t.code = MEDIA_BUS_FMT_SBGGR8_1X8,\n> +\t\t.bitsPerPixel = 8,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SGBRG8_1X8, {\n> +\t\t.name = \"SGBRG8_1X8\",\n> +\t\t.code = MEDIA_BUS_FMT_SGBRG8_1X8,\n> +\t\t.bitsPerPixel = 8,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SGRBG8_1X8, {\n> +\t\t.name = \"SGRBG8_1X8\",\n> +\t\t.code = MEDIA_BUS_FMT_SGRBG8_1X8,\n> +\t\t.bitsPerPixel = 8,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SRGGB8_1X8, {\n> +\t\t.name = \"SRGGB8_1X8\",\n> +\t\t.code = MEDIA_BUS_FMT_SRGGB8_1X8,\n> +\t\t.bitsPerPixel = 8,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SBGGR10_ALAW8_1X8, {\n> +\t\t.name = \"SBGGR10_ALAW8_1X8\",\n> +\t\t.code = MEDIA_BUS_FMT_SBGGR10_ALAW8_1X8,\n> +\t\t.bitsPerPixel = 8,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SGBRG10_ALAW8_1X8, {\n> +\t\t.name = \"SGBRG10_ALAW8_1X8\",\n> +\t\t.code = MEDIA_BUS_FMT_SGBRG10_ALAW8_1X8,\n> +\t\t.bitsPerPixel = 8,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SGRBG10_ALAW8_1X8, {\n> +\t\t.name = \"SGRBG10_ALAW8_1X8\",\n> +\t\t.code = MEDIA_BUS_FMT_SGRBG10_ALAW8_1X8,\n> +\t\t.bitsPerPixel = 8,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SRGGB10_ALAW8_1X8, {\n> +\t\t.name = \"SRGGB10_ALAW8_1X8\",\n> +\t\t.code = MEDIA_BUS_FMT_SRGGB10_ALAW8_1X8,\n> +\t\t.bitsPerPixel = 8,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SBGGR10_DPCM8_1X8, {\n> +\t\t.name = \"SBGGR10_DPCM8_1X8\",\n> +\t\t.code = MEDIA_BUS_FMT_SBGGR10_DPCM8_1X8,\n> +\t\t.bitsPerPixel = 8,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SGBRG10_DPCM8_1X8, {\n> +\t\t.name = \"SGBRG10_DPCM8_1X8\",\n> +\t\t.code = MEDIA_BUS_FMT_SGBRG10_DPCM8_1X8,\n> +\t\t.bitsPerPixel = 8,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SGRBG10_DPCM8_1X8, {\n> +\t\t.name = \"SGRBG10_DPCM8_1X8\",\n> +\t\t.code = MEDIA_BUS_FMT_SGRBG10_DPCM8_1X8,\n> +\t\t.bitsPerPixel = 8,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SRGGB10_DPCM8_1X8, {\n> +\t\t.name = \"SRGGB10_DPCM8_1X8\",\n> +\t\t.code = MEDIA_BUS_FMT_SRGGB10_DPCM8_1X8,\n> +\t\t.bitsPerPixel = 8,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SBGGR10_2X8_PADHI_BE, {\n> +\t\t.name = \"SBGGR10_2X8_PADHI_BE\",\n> +\t\t.code = MEDIA_BUS_FMT_SBGGR10_2X8_PADHI_BE,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SBGGR10_2X8_PADHI_LE, {\n> +\t\t.name = \"SBGGR10_2X8_PADHI_LE\",\n> +\t\t.code = MEDIA_BUS_FMT_SBGGR10_2X8_PADHI_LE,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SBGGR10_2X8_PADLO_BE, {\n> +\t\t.name = \"SBGGR10_2X8_PADLO_BE\",\n> +\t\t.code = MEDIA_BUS_FMT_SBGGR10_2X8_PADLO_BE,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SBGGR10_2X8_PADLO_LE, {\n> +\t\t.name = \"SBGGR10_2X8_PADLO_LE\",\n> +\t\t.code = MEDIA_BUS_FMT_SBGGR10_2X8_PADLO_LE,\n> +\t\t.bitsPerPixel = 16,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SBGGR10_1X10, {\n> +\t\t.name = \"SBGGR10_1X10\",\n> +\t\t.code = MEDIA_BUS_FMT_SBGGR10_1X10,\n> +\t\t.bitsPerPixel = 10,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SGBRG10_1X10, {\n> +\t\t.name = \"SGBRG10_1X10\",\n> +\t\t.code = MEDIA_BUS_FMT_SGBRG10_1X10,\n> +\t\t.bitsPerPixel = 10,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SGRBG10_1X10, {\n> +\t\t.name = \"SGRBG10_1X10\",\n> +\t\t.code = MEDIA_BUS_FMT_SGRBG10_1X10,\n> +\t\t.bitsPerPixel = 10,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SRGGB10_1X10, {\n> +\t\t.name = \"SRGGB10_1X10\",\n> +\t\t.code = MEDIA_BUS_FMT_SRGGB10_1X10,\n> +\t\t.bitsPerPixel = 10,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SBGGR12_1X12, {\n> +\t\t.name = \"SBGGR12_1X12\",\n> +\t\t.code = MEDIA_BUS_FMT_SBGGR12_1X12,\n> +\t\t.bitsPerPixel = 12,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SGBRG12_1X12, {\n> +\t\t.name = \"SGBRG12_1X12\",\n> +\t\t.code = MEDIA_BUS_FMT_SGBRG12_1X12,\n> +\t\t.bitsPerPixel = 12,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SGRBG12_1X12, {\n> +\t\t.name = \"SGRBG12_1X12\",\n> +\t\t.code = MEDIA_BUS_FMT_SGRBG12_1X12,\n> +\t\t.bitsPerPixel = 12,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_SRGGB12_1X12, {\n> +\t\t.name = \"SRGGB12_1X12\",\n> +\t\t.code = MEDIA_BUS_FMT_SRGGB12_1X12,\n> +\t\t.bitsPerPixel = 12,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> +\t} },\n>  \t/* \\todo Clarify colour encoding for HSV formats */\n> -\t{ MEDIA_BUS_FMT_AHSV8888_1X32, { 32, \"AHSV8888_1X32\", PixelFormatInfo::ColourEncodingRGB } },\n> -\t{ MEDIA_BUS_FMT_JPEG_1X8, { 8, \"JPEG_1X8\", PixelFormatInfo::ColourEncodingYUV } },\n> +\t{ MEDIA_BUS_FMT_AHSV8888_1X32, {\n> +\t\t.name = \"AHSV8888_1X32\",\n> +\t\t.code = MEDIA_BUS_FMT_AHSV8888_1X32,\n> +\t\t.bitsPerPixel = 32,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> +\t} },\n> +\t{ MEDIA_BUS_FMT_JPEG_1X8, {\n> +\t\t.name = \"JPEG_1X8\",\n> +\t\t.code = MEDIA_BUS_FMT_JPEG_1X8,\n> +\t\t.bitsPerPixel = 8,\n> +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> +\t} },\n>  };\n>\n>  } /* namespace */\n> --\n> Regards,\n>\n> Laurent Pinchart\n>","headers":{"Return-Path":"<libcamera-devel-bounces@lists.libcamera.org>","X-Original-To":"parsemail@patchwork.libcamera.org","Delivered-To":"parsemail@patchwork.libcamera.org","Received":["from lancelot.ideasonboard.com (lancelot.ideasonboard.com\n\t[92.243.16.209])\n\tby patchwork.libcamera.org (Postfix) with ESMTPS id 89888BD160\n\tfor <parsemail@patchwork.libcamera.org>;\n\tWed, 28 Feb 2024 08:27:33 +0000 (UTC)","from lancelot.ideasonboard.com (localhost [IPv6:::1])\n\tby lancelot.ideasonboard.com (Postfix) with ESMTP id DC9E262868;\n\tWed, 28 Feb 2024 09:27:32 +0100 (CET)","from perceval.ideasonboard.com (perceval.ideasonboard.com\n\t[213.167.242.64])\n\tby lancelot.ideasonboard.com (Postfix) with ESMTPS id 9065C627F9\n\tfor <libcamera-devel@lists.libcamera.org>;\n\tWed, 28 Feb 2024 09:27:31 +0100 (CET)","from ideasonboard.com (93-61-96-190.ip145.fastwebnet.it\n\t[93.61.96.190])\n\tby perceval.ideasonboard.com (Postfix) with ESMTPSA id BC02A672;\n\tWed, 28 Feb 2024 09:27:18 +0100 (CET)"],"Authentication-Results":"lancelot.ideasonboard.com; dkim=pass (1024-bit key;\n\tunprotected) header.d=ideasonboard.com header.i=@ideasonboard.com\n\theader.b=\"CKsYhIAm\"; dkim-atps=neutral","DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com;\n\ts=mail; t=1709108838;\n\tbh=uRMancaEWlCwkTPG94nZz0pfauInZ/Tjfxvq2AM/IMY=;\n\th=Date:From:To:Cc:Subject:References:In-Reply-To:From;\n\tb=CKsYhIAmNo2gXIwm0MfJtln5mNXFhk9RAEXD5mo0kOUzI4RvLqVfh34QqFgUpjvHt\n\tZi3i3IQu6gytP31UZgN+IdDXE+UvftYgEg8S7LIy8FaHmZUGK1VenQY5qO0hpRpZcg\n\tOnY43L5DVr2OuRnB/6wE57q0DZFWxT6Zf0fi99qo=","Date":"Wed, 28 Feb 2024 09:27:27 +0100","From":"Jacopo Mondi <jacopo.mondi@ideasonboard.com>","To":"Laurent Pinchart <laurent.pinchart@ideasonboard.com>","Subject":"Re: [PATCH 2/9] libcamera: v4l2_subdevice: Add code member to\n\tMediaBusFormatInfo","Message-ID":"<5xfnqqx6jenwc3oao3gfpuypvn45sfkqd7euxdxz4topaynl5n@bk6oyv3nubrf>","References":"<20240227140953.26093-1-laurent.pinchart@ideasonboard.com>\n\t<20240227140953.26093-3-laurent.pinchart@ideasonboard.com>","MIME-Version":"1.0","Content-Type":"text/plain; charset=utf-8","Content-Disposition":"inline","In-Reply-To":"<20240227140953.26093-3-laurent.pinchart@ideasonboard.com>","X-BeenThere":"libcamera-devel@lists.libcamera.org","X-Mailman-Version":"2.1.29","Precedence":"list","List-Id":"<libcamera-devel.lists.libcamera.org>","List-Unsubscribe":"<https://lists.libcamera.org/options/libcamera-devel>,\n\t<mailto:libcamera-devel-request@lists.libcamera.org?subject=unsubscribe>","List-Archive":"<https://lists.libcamera.org/pipermail/libcamera-devel/>","List-Post":"<mailto:libcamera-devel@lists.libcamera.org>","List-Help":"<mailto:libcamera-devel-request@lists.libcamera.org?subject=help>","List-Subscribe":"<https://lists.libcamera.org/listinfo/libcamera-devel>,\n\t<mailto:libcamera-devel-request@lists.libcamera.org?subject=subscribe>","Cc":"libcamera-devel@lists.libcamera.org","Errors-To":"libcamera-devel-bounces@lists.libcamera.org","Sender":"\"libcamera-devel\" <libcamera-devel-bounces@lists.libcamera.org>"}},{"id":28782,"web_url":"https://patchwork.libcamera.org/comment/28782/","msgid":"<20240228090556.GD3419@pendragon.ideasonboard.com>","date":"2024-02-28T09:05:56","subject":"Re: [PATCH 2/9] libcamera: v4l2_subdevice: Add code member to\n\tMediaBusFormatInfo","submitter":{"id":2,"url":"https://patchwork.libcamera.org/api/people/2/","name":"Laurent Pinchart","email":"laurent.pinchart@ideasonboard.com"},"content":"Hi Jacopo,\n\nOn Wed, Feb 28, 2024 at 09:27:27AM +0100, Jacopo Mondi wrote:\n> On Tue, Feb 27, 2024 at 04:09:46PM +0200, Laurent Pinchart wrote:\n> > To prepare for exposing the MediaBusFormatInfo structure as an internal\n> > API, add a code member to the structure to store the media bus code.\n> > This makes MediaBusFormatInfo usable standalone, without having to\n> > externally associate the code related to the info.\n> >\n> > The entries in the mediaBusFormatInfo map are becoming too long, so\n> > split them on multiple lines.\n> >\n> > While at it, swap the order of the members to match the PixelFormatInfo\n> > class for consistency.\n> >\n> > Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>\n> > ---\n> >  src/libcamera/v4l2_subdevice.cpp | 554 ++++++++++++++++++++++++++-----\n> >  1 file changed, 473 insertions(+), 81 deletions(-)\n> >\n> > diff --git a/src/libcamera/v4l2_subdevice.cpp b/src/libcamera/v4l2_subdevice.cpp\n> > index 6c1df7812f07..a74b8362b6d1 100644\n> > --- a/src/libcamera/v4l2_subdevice.cpp\n> > +++ b/src/libcamera/v4l2_subdevice.cpp\n> > @@ -41,13 +41,15 @@ namespace {\n> >  /*\n> >   * \\struct MediaBusFormatInfo\n> >   * \\brief Information about media bus formats\n> > - * \\param bitsPerPixel Bits per pixel\n> >   * \\param name Name of MBUS format\n> > + * \\param code The media bus format code\n> > + * \\param bitsPerPixel Bits per pixel\n> >   * \\param colourEncoding Type of colour encoding\n> >   */\n> >  struct MediaBusFormatInfo {\n> > -\tunsigned int bitsPerPixel;\n> >  \tconst char *name;\n> > +\tuint32_t code;\n> > +\tunsigned int bitsPerPixel;\n> >  \tPixelFormatInfo::ColourEncoding colourEncoding;\n> >  };\n> >\n> > @@ -56,87 +58,477 @@ struct MediaBusFormatInfo {\n> >   * \\brief A map that associates MediaBusFormatInfo struct to V4L2 media\n> >   * bus codes\n> >   */\n> > -const std::map<uint32_t, MediaBusFormatInfo> mediaBusFormatInfo = {\n> > +const std::map<uint32_t, MediaBusFormatInfo> mediaBusFormatInfo{\n> \n> Does this make any practical difference ? I guess the compiler is\n> smart enough to avoid constructing a map and then copying it ?\n\nHopefully it shouldn't make a difference, but I think it's best to use\nthe syntax corresponding to the desired behaviour nonetheless.\n\n> >  \t/* This table is sorted to match the order in linux/media-bus-format.h */\n> > -\t{ MEDIA_BUS_FMT_RGB444_2X8_PADHI_BE, { 16, \"RGB444_2X8_PADHI_BE\", PixelFormatInfo::ColourEncodingRGB } },\n> > -\t{ MEDIA_BUS_FMT_RGB444_2X8_PADHI_LE, { 16, \"RGB444_2X8_PADHI_LE\", PixelFormatInfo::ColourEncodingRGB } },\n> > -\t{ MEDIA_BUS_FMT_RGB555_2X8_PADHI_BE, { 16, \"RGB555_2X8_PADHI_BE\", PixelFormatInfo::ColourEncodingRGB } },\n> > -\t{ MEDIA_BUS_FMT_RGB555_2X8_PADHI_LE, { 16, \"RGB555_2X8_PADHI_LE\", PixelFormatInfo::ColourEncodingRGB } },\n> > -\t{ MEDIA_BUS_FMT_RGB565_1X16, { 16, \"RGB565_1X16\", PixelFormatInfo::ColourEncodingRGB } },\n> > -\t{ MEDIA_BUS_FMT_BGR565_2X8_BE, { 16, \"BGR565_2X8_BE\", PixelFormatInfo::ColourEncodingRGB } },\n> > -\t{ MEDIA_BUS_FMT_BGR565_2X8_LE, { 16, \"BGR565_2X8_LE\", PixelFormatInfo::ColourEncodingRGB } },\n> > -\t{ MEDIA_BUS_FMT_RGB565_2X8_BE, { 16, \"RGB565_2X8_BE\", PixelFormatInfo::ColourEncodingRGB } },\n> > -\t{ MEDIA_BUS_FMT_RGB565_2X8_LE, { 16, \"RGB565_2X8_LE\", PixelFormatInfo::ColourEncodingRGB } },\n> > -\t{ MEDIA_BUS_FMT_RGB666_1X18, { 18, \"RGB666_1X18\", PixelFormatInfo::ColourEncodingRGB } },\n> > -\t{ MEDIA_BUS_FMT_BGR888_1X24, { 24, \"BGR888_1X24\", PixelFormatInfo::ColourEncodingRGB } },\n> > -\t{ MEDIA_BUS_FMT_RGB888_1X24, { 24, \"RGB888_1X24\", PixelFormatInfo::ColourEncodingRGB } },\n> > -\t{ MEDIA_BUS_FMT_RGB888_2X12_BE, { 24, \"RGB888_2X12_BE\", PixelFormatInfo::ColourEncodingRGB } },\n> > -\t{ MEDIA_BUS_FMT_RGB888_2X12_LE, { 24, \"RGB888_2X12_LE\", PixelFormatInfo::ColourEncodingRGB } },\n> > -\t{ MEDIA_BUS_FMT_ARGB8888_1X32, { 32, \"ARGB8888_1X32\", PixelFormatInfo::ColourEncodingRGB } },\n> > -\t{ MEDIA_BUS_FMT_Y8_1X8, { 8, \"Y8_1X8\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_UV8_1X8, { 8, \"UV8_1X8\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_UYVY8_1_5X8, { 12, \"UYVY8_1_5X8\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_VYUY8_1_5X8, { 12, \"VYUY8_1_5X8\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_YUYV8_1_5X8, { 12, \"YUYV8_1_5X8\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_YVYU8_1_5X8, { 12, \"YVYU8_1_5X8\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_UYVY8_2X8, { 16, \"UYVY8_2X8\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_VYUY8_2X8, { 16, \"VYUY8_2X8\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_YUYV8_2X8, { 16, \"YUYV8_2X8\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_YVYU8_2X8, { 16, \"YVYU8_2X8\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_Y10_1X10, { 10, \"Y10_1X10\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_UYVY10_2X10, { 20, \"UYVY10_2X10\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_VYUY10_2X10, { 20, \"VYUY10_2X10\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_YUYV10_2X10, { 20, \"YUYV10_2X10\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_YVYU10_2X10, { 20, \"YVYU10_2X10\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_Y12_1X12, { 12, \"Y12_1X12\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_Y16_1X16, { 16, \"Y16_1X16\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_UYVY8_1X16, { 16, \"UYVY8_1X16\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_VYUY8_1X16, { 16, \"VYUY8_1X16\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_YUYV8_1X16, { 16, \"YUYV8_1X16\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_YVYU8_1X16, { 16, \"YVYU8_1X16\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_YDYUYDYV8_1X16, { 16, \"YDYUYDYV8_1X16\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_UYVY10_1X20, { 20, \"UYVY10_1X20\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_VYUY10_1X20, { 20, \"VYUY10_1X20\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_YUYV10_1X20, { 20, \"YUYV10_1X20\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_YVYU10_1X20, { 20, \"YVYU10_1X20\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_YUV8_1X24, { 24, \"YUV8_1X24\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_YUV10_1X30, { 30, \"YUV10_1X30\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_AYUV8_1X32, { 32, \"AYUV8_1X32\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_UYVY12_2X12, { 24, \"UYVY12_2X12\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_VYUY12_2X12, { 24, \"VYUY12_2X12\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_YUYV12_2X12, { 24, \"YUYV12_2X12\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_YVYU12_2X12, { 24, \"YVYU12_2X12\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_UYVY12_1X24, { 24, \"UYVY12_1X24\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_VYUY12_1X24, { 24, \"VYUY12_1X24\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_YUYV12_1X24, { 24, \"YUYV12_1X24\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_YVYU12_1X24, { 24, \"YVYU12_1X24\", PixelFormatInfo::ColourEncodingYUV } },\n> > -\t{ MEDIA_BUS_FMT_SBGGR8_1X8, { 8, \"SBGGR8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SGBRG8_1X8, { 8, \"SGBRG8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SGRBG8_1X8, { 8, \"SGRBG8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SRGGB8_1X8, { 8, \"SRGGB8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SBGGR10_ALAW8_1X8, { 8, \"SBGGR10_ALAW8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SGBRG10_ALAW8_1X8, { 8, \"SGBRG10_ALAW8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SGRBG10_ALAW8_1X8, { 8, \"SGRBG10_ALAW8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SRGGB10_ALAW8_1X8, { 8, \"SRGGB10_ALAW8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SBGGR10_DPCM8_1X8, { 8, \"SBGGR10_DPCM8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SGBRG10_DPCM8_1X8, { 8, \"SGBRG10_DPCM8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SGRBG10_DPCM8_1X8, { 8, \"SGRBG10_DPCM8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SRGGB10_DPCM8_1X8, { 8, \"SRGGB10_DPCM8_1X8\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SBGGR10_2X8_PADHI_BE, { 16, \"SBGGR10_2X8_PADHI_BE\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SBGGR10_2X8_PADHI_LE, { 16, \"SBGGR10_2X8_PADHI_LE\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SBGGR10_2X8_PADLO_BE, { 16, \"SBGGR10_2X8_PADLO_BE\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SBGGR10_2X8_PADLO_LE, { 16, \"SBGGR10_2X8_PADLO_LE\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SBGGR10_1X10, { 10, \"SBGGR10_1X10\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SGBRG10_1X10, { 10, \"SGBRG10_1X10\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SGRBG10_1X10, { 10, \"SGRBG10_1X10\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SRGGB10_1X10, { 10, \"SRGGB10_1X10\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SBGGR12_1X12, { 12, \"SBGGR12_1X12\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SGBRG12_1X12, { 12, \"SGBRG12_1X12\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SGRBG12_1X12, { 12, \"SGRBG12_1X12\", PixelFormatInfo::ColourEncodingRAW } },\n> > -\t{ MEDIA_BUS_FMT_SRGGB12_1X12, { 12, \"SRGGB12_1X12\", PixelFormatInfo::ColourEncodingRAW } },\n> > +\t{ MEDIA_BUS_FMT_RGB444_2X8_PADHI_BE, {\n> > +\t\t.name = \"RGB444_2X8_PADHI_BE\",\n> > +\t\t.code = MEDIA_BUS_FMT_RGB444_2X8_PADHI_BE,\n> \n> So we now have the map indexed by media bus code, and the media bus\n> info contains the code.\n> \n> I wonder if we need a map, or we can just provide an helper to search\n> the media bus info entries by code, to avoid duplicating the\n> information (it shouldn't be hard to keep them in sync, so it's maybe\n> not a big deal).\n\nAs the map grows, lookup operations will perform better with O(log(n))\nthan O(n).\n\n> This apart\n> Reviewed-by: Jacopo Mondi <jacopo.mondi@ideasonboard.com>\n> \n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_RGB444_2X8_PADHI_LE, {\n> > +\t\t.name = \"RGB444_2X8_PADHI_LE\",\n> > +\t\t.code = MEDIA_BUS_FMT_RGB444_2X8_PADHI_LE,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_RGB555_2X8_PADHI_BE, {\n> > +\t\t.name = \"RGB555_2X8_PADHI_BE\",\n> > +\t\t.code = MEDIA_BUS_FMT_RGB555_2X8_PADHI_BE,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_RGB555_2X8_PADHI_LE, {\n> > +\t\t.name = \"RGB555_2X8_PADHI_LE\",\n> > +\t\t.code = MEDIA_BUS_FMT_RGB555_2X8_PADHI_LE,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_RGB565_1X16, {\n> > +\t\t.name = \"RGB565_1X16\",\n> > +\t\t.code = MEDIA_BUS_FMT_RGB565_1X16,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_BGR565_2X8_BE, {\n> > +\t\t.name = \"BGR565_2X8_BE\",\n> > +\t\t.code = MEDIA_BUS_FMT_BGR565_2X8_BE,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_BGR565_2X8_LE, {\n> > +\t\t.name = \"BGR565_2X8_LE\",\n> > +\t\t.code = MEDIA_BUS_FMT_BGR565_2X8_LE,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_RGB565_2X8_BE, {\n> > +\t\t.name = \"RGB565_2X8_BE\",\n> > +\t\t.code = MEDIA_BUS_FMT_RGB565_2X8_BE,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_RGB565_2X8_LE, {\n> > +\t\t.name = \"RGB565_2X8_LE\",\n> > +\t\t.code = MEDIA_BUS_FMT_RGB565_2X8_LE,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_RGB666_1X18, {\n> > +\t\t.name = \"RGB666_1X18\",\n> > +\t\t.code = MEDIA_BUS_FMT_RGB666_1X18,\n> > +\t\t.bitsPerPixel = 18,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_BGR888_1X24, {\n> > +\t\t.name = \"BGR888_1X24\",\n> > +\t\t.code = MEDIA_BUS_FMT_BGR888_1X24,\n> > +\t\t.bitsPerPixel = 24,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_RGB888_1X24, {\n> > +\t\t.name = \"RGB888_1X24\",\n> > +\t\t.code = MEDIA_BUS_FMT_RGB888_1X24,\n> > +\t\t.bitsPerPixel = 24,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_RGB888_2X12_BE, {\n> > +\t\t.name = \"RGB888_2X12_BE\",\n> > +\t\t.code = MEDIA_BUS_FMT_RGB888_2X12_BE,\n> > +\t\t.bitsPerPixel = 24,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_RGB888_2X12_LE, {\n> > +\t\t.name = \"RGB888_2X12_LE\",\n> > +\t\t.code = MEDIA_BUS_FMT_RGB888_2X12_LE,\n> > +\t\t.bitsPerPixel = 24,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_ARGB8888_1X32, {\n> > +\t\t.name = \"ARGB8888_1X32\",\n> > +\t\t.code = MEDIA_BUS_FMT_ARGB8888_1X32,\n> > +\t\t.bitsPerPixel = 32,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_Y8_1X8, {\n> > +\t\t.name = \"Y8_1X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_Y8_1X8,\n> > +\t\t.bitsPerPixel = 8,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_UV8_1X8, {\n> > +\t\t.name = \"UV8_1X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_UV8_1X8,\n> > +\t\t.bitsPerPixel = 8,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_UYVY8_1_5X8, {\n> > +\t\t.name = \"UYVY8_1_5X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_UYVY8_1_5X8,\n> > +\t\t.bitsPerPixel = 12,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_VYUY8_1_5X8, {\n> > +\t\t.name = \"VYUY8_1_5X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_VYUY8_1_5X8,\n> > +\t\t.bitsPerPixel = 12,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_YUYV8_1_5X8, {\n> > +\t\t.name = \"YUYV8_1_5X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_YUYV8_1_5X8,\n> > +\t\t.bitsPerPixel = 12,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_YVYU8_1_5X8, {\n> > +\t\t.name = \"YVYU8_1_5X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_YVYU8_1_5X8,\n> > +\t\t.bitsPerPixel = 12,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_UYVY8_2X8, {\n> > +\t\t.name = \"UYVY8_2X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_UYVY8_2X8,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_VYUY8_2X8, {\n> > +\t\t.name = \"VYUY8_2X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_VYUY8_2X8,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_YUYV8_2X8, {\n> > +\t\t.name = \"YUYV8_2X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_YUYV8_2X8,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_YVYU8_2X8, {\n> > +\t\t.name = \"YVYU8_2X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_YVYU8_2X8,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_Y10_1X10, {\n> > +\t\t.name = \"Y10_1X10\",\n> > +\t\t.code = MEDIA_BUS_FMT_Y10_1X10,\n> > +\t\t.bitsPerPixel = 10,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_UYVY10_2X10, {\n> > +\t\t.name = \"UYVY10_2X10\",\n> > +\t\t.code = MEDIA_BUS_FMT_UYVY10_2X10,\n> > +\t\t.bitsPerPixel = 20,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_VYUY10_2X10, {\n> > +\t\t.name = \"VYUY10_2X10\",\n> > +\t\t.code = MEDIA_BUS_FMT_VYUY10_2X10,\n> > +\t\t.bitsPerPixel = 20,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_YUYV10_2X10, {\n> > +\t\t.name = \"YUYV10_2X10\",\n> > +\t\t.code = MEDIA_BUS_FMT_YUYV10_2X10,\n> > +\t\t.bitsPerPixel = 20,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_YVYU10_2X10, {\n> > +\t\t.name = \"YVYU10_2X10\",\n> > +\t\t.code = MEDIA_BUS_FMT_YVYU10_2X10,\n> > +\t\t.bitsPerPixel = 20,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_Y12_1X12, {\n> > +\t\t.name = \"Y12_1X12\",\n> > +\t\t.code = MEDIA_BUS_FMT_Y12_1X12,\n> > +\t\t.bitsPerPixel = 12,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_Y16_1X16, {\n> > +\t\t.name = \"Y16_1X16\",\n> > +\t\t.code = MEDIA_BUS_FMT_Y16_1X16,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_UYVY8_1X16, {\n> > +\t\t.name = \"UYVY8_1X16\",\n> > +\t\t.code = MEDIA_BUS_FMT_UYVY8_1X16,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_VYUY8_1X16, {\n> > +\t\t.name = \"VYUY8_1X16\",\n> > +\t\t.code = MEDIA_BUS_FMT_VYUY8_1X16,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_YUYV8_1X16, {\n> > +\t\t.name = \"YUYV8_1X16\",\n> > +\t\t.code = MEDIA_BUS_FMT_YUYV8_1X16,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_YVYU8_1X16, {\n> > +\t\t.name = \"YVYU8_1X16\",\n> > +\t\t.code = MEDIA_BUS_FMT_YVYU8_1X16,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_YDYUYDYV8_1X16, {\n> > +\t\t.name = \"YDYUYDYV8_1X16\",\n> > +\t\t.code = MEDIA_BUS_FMT_YDYUYDYV8_1X16,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_UYVY10_1X20, {\n> > +\t\t.name = \"UYVY10_1X20\",\n> > +\t\t.code = MEDIA_BUS_FMT_UYVY10_1X20,\n> > +\t\t.bitsPerPixel = 20,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_VYUY10_1X20, {\n> > +\t\t.name = \"VYUY10_1X20\",\n> > +\t\t.code = MEDIA_BUS_FMT_VYUY10_1X20,\n> > +\t\t.bitsPerPixel = 20,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_YUYV10_1X20, {\n> > +\t\t.name = \"YUYV10_1X20\",\n> > +\t\t.code = MEDIA_BUS_FMT_YUYV10_1X20,\n> > +\t\t.bitsPerPixel = 20,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_YVYU10_1X20, {\n> > +\t\t.name = \"YVYU10_1X20\",\n> > +\t\t.code = MEDIA_BUS_FMT_YVYU10_1X20,\n> > +\t\t.bitsPerPixel = 20,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_YUV8_1X24, {\n> > +\t\t.name = \"YUV8_1X24\",\n> > +\t\t.code = MEDIA_BUS_FMT_YUV8_1X24,\n> > +\t\t.bitsPerPixel = 24,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_YUV10_1X30, {\n> > +\t\t.name = \"YUV10_1X30\",\n> > +\t\t.code = MEDIA_BUS_FMT_YUV10_1X30,\n> > +\t\t.bitsPerPixel = 30,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_AYUV8_1X32, {\n> > +\t\t.name = \"AYUV8_1X32\",\n> > +\t\t.code = MEDIA_BUS_FMT_AYUV8_1X32,\n> > +\t\t.bitsPerPixel = 32,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_UYVY12_2X12, {\n> > +\t\t.name = \"UYVY12_2X12\",\n> > +\t\t.code = MEDIA_BUS_FMT_UYVY12_2X12,\n> > +\t\t.bitsPerPixel = 24,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_VYUY12_2X12, {\n> > +\t\t.name = \"VYUY12_2X12\",\n> > +\t\t.code = MEDIA_BUS_FMT_VYUY12_2X12,\n> > +\t\t.bitsPerPixel = 24,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_YUYV12_2X12, {\n> > +\t\t.name = \"YUYV12_2X12\",\n> > +\t\t.code = MEDIA_BUS_FMT_YUYV12_2X12,\n> > +\t\t.bitsPerPixel = 24,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_YVYU12_2X12, {\n> > +\t\t.name = \"YVYU12_2X12\",\n> > +\t\t.code = MEDIA_BUS_FMT_YVYU12_2X12,\n> > +\t\t.bitsPerPixel = 24,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_UYVY12_1X24, {\n> > +\t\t.name = \"UYVY12_1X24\",\n> > +\t\t.code = MEDIA_BUS_FMT_UYVY12_1X24,\n> > +\t\t.bitsPerPixel = 24,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_VYUY12_1X24, {\n> > +\t\t.name = \"VYUY12_1X24\",\n> > +\t\t.code = MEDIA_BUS_FMT_VYUY12_1X24,\n> > +\t\t.bitsPerPixel = 24,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_YUYV12_1X24, {\n> > +\t\t.name = \"YUYV12_1X24\",\n> > +\t\t.code = MEDIA_BUS_FMT_YUYV12_1X24,\n> > +\t\t.bitsPerPixel = 24,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_YVYU12_1X24, {\n> > +\t\t.name = \"YVYU12_1X24\",\n> > +\t\t.code = MEDIA_BUS_FMT_YVYU12_1X24,\n> > +\t\t.bitsPerPixel = 24,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SBGGR8_1X8, {\n> > +\t\t.name = \"SBGGR8_1X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_SBGGR8_1X8,\n> > +\t\t.bitsPerPixel = 8,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SGBRG8_1X8, {\n> > +\t\t.name = \"SGBRG8_1X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_SGBRG8_1X8,\n> > +\t\t.bitsPerPixel = 8,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SGRBG8_1X8, {\n> > +\t\t.name = \"SGRBG8_1X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_SGRBG8_1X8,\n> > +\t\t.bitsPerPixel = 8,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SRGGB8_1X8, {\n> > +\t\t.name = \"SRGGB8_1X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_SRGGB8_1X8,\n> > +\t\t.bitsPerPixel = 8,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SBGGR10_ALAW8_1X8, {\n> > +\t\t.name = \"SBGGR10_ALAW8_1X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_SBGGR10_ALAW8_1X8,\n> > +\t\t.bitsPerPixel = 8,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SGBRG10_ALAW8_1X8, {\n> > +\t\t.name = \"SGBRG10_ALAW8_1X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_SGBRG10_ALAW8_1X8,\n> > +\t\t.bitsPerPixel = 8,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SGRBG10_ALAW8_1X8, {\n> > +\t\t.name = \"SGRBG10_ALAW8_1X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_SGRBG10_ALAW8_1X8,\n> > +\t\t.bitsPerPixel = 8,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SRGGB10_ALAW8_1X8, {\n> > +\t\t.name = \"SRGGB10_ALAW8_1X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_SRGGB10_ALAW8_1X8,\n> > +\t\t.bitsPerPixel = 8,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SBGGR10_DPCM8_1X8, {\n> > +\t\t.name = \"SBGGR10_DPCM8_1X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_SBGGR10_DPCM8_1X8,\n> > +\t\t.bitsPerPixel = 8,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SGBRG10_DPCM8_1X8, {\n> > +\t\t.name = \"SGBRG10_DPCM8_1X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_SGBRG10_DPCM8_1X8,\n> > +\t\t.bitsPerPixel = 8,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SGRBG10_DPCM8_1X8, {\n> > +\t\t.name = \"SGRBG10_DPCM8_1X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_SGRBG10_DPCM8_1X8,\n> > +\t\t.bitsPerPixel = 8,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SRGGB10_DPCM8_1X8, {\n> > +\t\t.name = \"SRGGB10_DPCM8_1X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_SRGGB10_DPCM8_1X8,\n> > +\t\t.bitsPerPixel = 8,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SBGGR10_2X8_PADHI_BE, {\n> > +\t\t.name = \"SBGGR10_2X8_PADHI_BE\",\n> > +\t\t.code = MEDIA_BUS_FMT_SBGGR10_2X8_PADHI_BE,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SBGGR10_2X8_PADHI_LE, {\n> > +\t\t.name = \"SBGGR10_2X8_PADHI_LE\",\n> > +\t\t.code = MEDIA_BUS_FMT_SBGGR10_2X8_PADHI_LE,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SBGGR10_2X8_PADLO_BE, {\n> > +\t\t.name = \"SBGGR10_2X8_PADLO_BE\",\n> > +\t\t.code = MEDIA_BUS_FMT_SBGGR10_2X8_PADLO_BE,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SBGGR10_2X8_PADLO_LE, {\n> > +\t\t.name = \"SBGGR10_2X8_PADLO_LE\",\n> > +\t\t.code = MEDIA_BUS_FMT_SBGGR10_2X8_PADLO_LE,\n> > +\t\t.bitsPerPixel = 16,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SBGGR10_1X10, {\n> > +\t\t.name = \"SBGGR10_1X10\",\n> > +\t\t.code = MEDIA_BUS_FMT_SBGGR10_1X10,\n> > +\t\t.bitsPerPixel = 10,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SGBRG10_1X10, {\n> > +\t\t.name = \"SGBRG10_1X10\",\n> > +\t\t.code = MEDIA_BUS_FMT_SGBRG10_1X10,\n> > +\t\t.bitsPerPixel = 10,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SGRBG10_1X10, {\n> > +\t\t.name = \"SGRBG10_1X10\",\n> > +\t\t.code = MEDIA_BUS_FMT_SGRBG10_1X10,\n> > +\t\t.bitsPerPixel = 10,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SRGGB10_1X10, {\n> > +\t\t.name = \"SRGGB10_1X10\",\n> > +\t\t.code = MEDIA_BUS_FMT_SRGGB10_1X10,\n> > +\t\t.bitsPerPixel = 10,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SBGGR12_1X12, {\n> > +\t\t.name = \"SBGGR12_1X12\",\n> > +\t\t.code = MEDIA_BUS_FMT_SBGGR12_1X12,\n> > +\t\t.bitsPerPixel = 12,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SGBRG12_1X12, {\n> > +\t\t.name = \"SGBRG12_1X12\",\n> > +\t\t.code = MEDIA_BUS_FMT_SGBRG12_1X12,\n> > +\t\t.bitsPerPixel = 12,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SGRBG12_1X12, {\n> > +\t\t.name = \"SGRBG12_1X12\",\n> > +\t\t.code = MEDIA_BUS_FMT_SGRBG12_1X12,\n> > +\t\t.bitsPerPixel = 12,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_SRGGB12_1X12, {\n> > +\t\t.name = \"SRGGB12_1X12\",\n> > +\t\t.code = MEDIA_BUS_FMT_SRGGB12_1X12,\n> > +\t\t.bitsPerPixel = 12,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRAW,\n> > +\t} },\n> >  \t/* \\todo Clarify colour encoding for HSV formats */\n> > -\t{ MEDIA_BUS_FMT_AHSV8888_1X32, { 32, \"AHSV8888_1X32\", PixelFormatInfo::ColourEncodingRGB } },\n> > -\t{ MEDIA_BUS_FMT_JPEG_1X8, { 8, \"JPEG_1X8\", PixelFormatInfo::ColourEncodingYUV } },\n> > +\t{ MEDIA_BUS_FMT_AHSV8888_1X32, {\n> > +\t\t.name = \"AHSV8888_1X32\",\n> > +\t\t.code = MEDIA_BUS_FMT_AHSV8888_1X32,\n> > +\t\t.bitsPerPixel = 32,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingRGB,\n> > +\t} },\n> > +\t{ MEDIA_BUS_FMT_JPEG_1X8, {\n> > +\t\t.name = \"JPEG_1X8\",\n> > +\t\t.code = MEDIA_BUS_FMT_JPEG_1X8,\n> > +\t\t.bitsPerPixel = 8,\n> > +\t\t.colourEncoding = PixelFormatInfo::ColourEncodingYUV,\n> > +\t} },\n> >  };\n> >\n> >  } /* namespace */","headers":{"Return-Path":"<libcamera-devel-bounces@lists.libcamera.org>","X-Original-To":"parsemail@patchwork.libcamera.org","Delivered-To":"parsemail@patchwork.libcamera.org","Received":["from lancelot.ideasonboard.com (lancelot.ideasonboard.com\n\t[92.243.16.209])\n\tby patchwork.libcamera.org (Postfix) with ESMTPS id 4E4BEBD80A\n\tfor <parsemail@patchwork.libcamera.org>;\n\tWed, 28 Feb 2024 09:05:57 +0000 (UTC)","from lancelot.ideasonboard.com (localhost [IPv6:::1])\n\tby lancelot.ideasonboard.com (Postfix) with ESMTP id 83C3862865;\n\tWed, 28 Feb 2024 10:05:56 +0100 (CET)","from perceval.ideasonboard.com (perceval.ideasonboard.com\n\t[IPv6:2001:4b98:dc2:55:216:3eff:fef7:d647])\n\tby lancelot.ideasonboard.com (Postfix) with ESMTPS id D36B6627F9\n\tfor <libcamera-devel@lists.libcamera.org>;\n\tWed, 28 Feb 2024 10:05:54 +0100 (CET)","from pendragon.ideasonboard.com (89-27-53-110.bb.dnainternet.fi\n\t[89.27.53.110])\n\tby perceval.ideasonboard.com (Postfix) with ESMTPSA id DD99F2B3;\n\tWed, 28 Feb 2024 10:05:41 +0100 (CET)"],"Authentication-Results":"lancelot.ideasonboard.com; dkim=pass (1024-bit key;\n\tunprotected) header.d=ideasonboard.com header.i=@ideasonboard.com\n\theader.b=\"G600fqoP\"; dkim-atps=neutral","DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com;\n\ts=mail; t=1709111142;\n\tbh=VdmuhH8CHe1dZILIPzGp8cjHao4AzxISlsvOV3Dat6A=;\n\th=Date:From:To:Cc:Subject:References:In-Reply-To:From;\n\tb=G600fqoPFsb1znhFUptW0Dv/HWE4LXaDhFPcr3G5Zs/j6YLXOO3u3NMQxFed5ndwk\n\tU1voyDlr7FODOoWpbtuFbg6uDe3cE/rp7Fxn731eKvLZqHa6qjt5VXII1xpKAvOCdh\n\tG3dd2peT2wcqx3uHEaKe1Z1kXUY9hXMkwgkXx/x0=","Date":"Wed, 28 Feb 2024 11:05:56 +0200","From":"Laurent Pinchart <laurent.pinchart@ideasonboard.com>","To":"Jacopo Mondi <jacopo.mondi@ideasonboard.com>","Subject":"Re: [PATCH 2/9] libcamera: v4l2_subdevice: Add code member to\n\tMediaBusFormatInfo","Message-ID":"<20240228090556.GD3419@pendragon.ideasonboard.com>","References":"<20240227140953.26093-1-laurent.pinchart@ideasonboard.com>\n\t<20240227140953.26093-3-laurent.pinchart@ideasonboard.com>\n\t<5xfnqqx6jenwc3oao3gfpuypvn45sfkqd7euxdxz4topaynl5n@bk6oyv3nubrf>","MIME-Version":"1.0","Content-Type":"text/plain; charset=utf-8","Content-Disposition":"inline","In-Reply-To":"<5xfnqqx6jenwc3oao3gfpuypvn45sfkqd7euxdxz4topaynl5n@bk6oyv3nubrf>","X-BeenThere":"libcamera-devel@lists.libcamera.org","X-Mailman-Version":"2.1.29","Precedence":"list","List-Id":"<libcamera-devel.lists.libcamera.org>","List-Unsubscribe":"<https://lists.libcamera.org/options/libcamera-devel>,\n\t<mailto:libcamera-devel-request@lists.libcamera.org?subject=unsubscribe>","List-Archive":"<https://lists.libcamera.org/pipermail/libcamera-devel/>","List-Post":"<mailto:libcamera-devel@lists.libcamera.org>","List-Help":"<mailto:libcamera-devel-request@lists.libcamera.org?subject=help>","List-Subscribe":"<https://lists.libcamera.org/listinfo/libcamera-devel>,\n\t<mailto:libcamera-devel-request@lists.libcamera.org?subject=subscribe>","Cc":"libcamera-devel@lists.libcamera.org","Errors-To":"libcamera-devel-bounces@lists.libcamera.org","Sender":"\"libcamera-devel\" <libcamera-devel-bounces@lists.libcamera.org>"}}]