Patch Detail
Show a patch.
GET /api/patches/2217/?format=api
{ "id": 2217, "url": "https://patchwork.libcamera.org/api/patches/2217/?format=api", "web_url": "https://patchwork.libcamera.org/patch/2217/", "project": { "id": 1, "url": "https://patchwork.libcamera.org/api/projects/1/?format=api", "name": "libcamera", "link_name": "libcamera", "list_id": "libcamera_core", "list_email": "libcamera-devel@lists.libcamera.org", "web_url": "", "scm_url": "", "webscm_url": "" }, "msgid": "<20191025032016.18904-1-laurent.pinchart@ideasonboard.com>", "date": "2019-10-25T03:20:16", "name": "[libcamera-devel] libcamera: pipeline: vimc: Support format enumeration", "commit_ref": "429be98e4cbf4aae889675568abbd108cf7f4691", "pull_url": null, "state": "accepted", "archived": false, "hash": "8b8752dbc0c814613b979e960a8982ac462a5ab5", "submitter": { "id": 2, "url": "https://patchwork.libcamera.org/api/people/2/?format=api", "name": "Laurent Pinchart", "email": "laurent.pinchart@ideasonboard.com" }, "delegate": null, "mbox": "https://patchwork.libcamera.org/patch/2217/mbox/", "series": [ { "id": 545, "url": "https://patchwork.libcamera.org/api/series/545/?format=api", "web_url": "https://patchwork.libcamera.org/project/libcamera/list/?series=545", "date": "2019-10-25T03:20:16", "name": "[libcamera-devel] libcamera: pipeline: vimc: Support format enumeration", "version": 1, "mbox": "https://patchwork.libcamera.org/series/545/mbox/" } ], "comments": "https://patchwork.libcamera.org/api/patches/2217/comments/", "check": "pending", "checks": "https://patchwork.libcamera.org/api/patches/2217/checks/", "tags": {}, "headers": { "Return-Path": "<laurent.pinchart@ideasonboard.com>", "Received": [ "from perceval.ideasonboard.com (perceval.ideasonboard.com\n\t[213.167.242.64])\n\tby lancelot.ideasonboard.com (Postfix) with ESMTPS id AB6CD61374\n\tfor <libcamera-devel@lists.libcamera.org>;\n\tFri, 25 Oct 2019 05:20:27 +0200 (CEST)", "from pendragon.ideasonboard.com (143.121.2.93.rev.sfr.net\n\t[93.2.121.143])\n\tby perceval.ideasonboard.com (Postfix) with ESMTPSA id 3D01233A\n\tfor <libcamera-devel@lists.libcamera.org>;\n\tFri, 25 Oct 2019 05:20:27 +0200 (CEST)" ], "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com;\n\ts=mail; t=1571973627;\n\tbh=AM8bjA52l47ee9vSJVP+8sooVCU3lBFZ+wWrDlKceME=;\n\th=From:To:Subject:Date:From;\n\tb=Cz07JIVBhDq5CKknsuwbi1rPo6vElv7sKkWQkdTkI8QN5/e8L6hax6sKQ4jskBXuY\n\tgNUglRgxF07XXjNvoz3F01EgeRlWQBotad8g5MsprgKxwMr3PDYmeD5jBnNGxLSPSn\n\tmIuBGoh27z/48RazhXosqq3KKz4xXPKzVmHK8JWk=", "From": "Laurent Pinchart <laurent.pinchart@ideasonboard.com>", "To": "libcamera-devel@lists.libcamera.org", "Date": "Fri, 25 Oct 2019 06:20:16 +0300", "Message-Id": "<20191025032016.18904-1-laurent.pinchart@ideasonboard.com>", "X-Mailer": "git-send-email 2.23.0", "MIME-Version": "1.0", "Content-Transfer-Encoding": "8bit", "Subject": "[libcamera-devel] [PATCH] libcamera: pipeline: vimc: Support format\n\tenumeration", "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>", "X-List-Received-Date": "Fri, 25 Oct 2019 03:20:27 -0000" }, "content": "Fill the StreamConfiguration with all supported formats. The list of\nsupported formats is currently hardcoded based on the limits of the vimc\ndriver.\n\nSigned-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>\n---\n src/libcamera/pipeline/vimc.cpp | 33 ++++++++++++++++++++++++---------\n 1 file changed, 24 insertions(+), 9 deletions(-)", "diff": "diff --git a/src/libcamera/pipeline/vimc.cpp b/src/libcamera/pipeline/vimc.cpp\nindex dcdaef120ad1..c16ae4cb76b5 100644\n--- a/src/libcamera/pipeline/vimc.cpp\n+++ b/src/libcamera/pipeline/vimc.cpp\n@@ -103,6 +103,16 @@ private:\n \t}\n };\n \n+namespace {\n+\n+constexpr std::array<unsigned int, 3> pixelformats{\n+\tV4L2_PIX_FMT_BGR24,\n+\tV4L2_PIX_FMT_RGB24,\n+\tV4L2_PIX_FMT_ARGB32,\n+};\n+\n+} /* namespace */\n+\n VimcCameraConfiguration::VimcCameraConfiguration()\n \t: CameraConfiguration()\n {\n@@ -110,12 +120,6 @@ VimcCameraConfiguration::VimcCameraConfiguration()\n \n CameraConfiguration::Status VimcCameraConfiguration::validate()\n {\n-\tstatic const std::array<unsigned int, 3> formats{\n-\t\tV4L2_PIX_FMT_BGR24,\n-\t\tV4L2_PIX_FMT_RGB24,\n-\t\tV4L2_PIX_FMT_ARGB32,\n-\t};\n-\n \tStatus status = Valid;\n \n \tif (config_.empty())\n@@ -130,8 +134,8 @@ CameraConfiguration::Status VimcCameraConfiguration::validate()\n \tStreamConfiguration &cfg = config_[0];\n \n \t/* Adjust the pixel format. */\n-\tif (std::find(formats.begin(), formats.end(), cfg.pixelFormat) ==\n-\t formats.end()) {\n+\tif (std::find(pixelformats.begin(), pixelformats.end(), cfg.pixelFormat) ==\n+\t pixelformats.end()) {\n \t\tLOG(VIMC, Debug) << \"Adjusting format to RGB24\";\n \t\tcfg.pixelFormat = V4L2_PIX_FMT_RGB24;\n \t\tstatus = Adjusted;\n@@ -170,7 +174,18 @@ CameraConfiguration *PipelineHandlerVimc::generateConfiguration(Camera *camera,\n \tif (roles.empty())\n \t\treturn config;\n \n-\tStreamConfiguration cfg{};\n+\tImageFormats formats;\n+\n+\tfor (unsigned int pixelformat : pixelformats) {\n+\t\t/* The scaler hardcodes a x3 scale-up ratio. */\n+\t\tstd::vector<SizeRange> sizes{\n+\t\t\tSizeRange{ 48, 48, 4096, 2160 }\n+\t\t};\n+\t\tformats.addFormat(pixelformat, sizes);\n+\t}\n+\n+\tStreamConfiguration cfg(formats.data());\n+\n \tcfg.pixelFormat = V4L2_PIX_FMT_RGB24;\n \tcfg.size = { 1920, 1080 };\n \tcfg.bufferCount = 4;\n", "prefixes": [ "libcamera-devel" ] }