Cover Letter Detail
Show a cover letter.
GET /api/1.1/covers/24568/?format=api
{ "id": 24568, "url": "https://patchwork.libcamera.org/api/1.1/covers/24568/?format=api", "web_url": "https://patchwork.libcamera.org/cover/24568/", "project": { "id": 1, "url": "https://patchwork.libcamera.org/api/1.1/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": "<20251007-v4l2-params-v5-0-8db451a81398@ideasonboard.com>", "date": "2025-10-07T18:17:42", "name": "[v5,0/5] ipa: libipa: Introduce V4L2Params", "submitter": { "id": 143, "url": "https://patchwork.libcamera.org/api/1.1/people/143/?format=api", "name": "Jacopo Mondi", "email": "jacopo.mondi@ideasonboard.com" }, "mbox": "https://patchwork.libcamera.org/cover/24568/mbox/", "series": [ { "id": 5480, "url": "https://patchwork.libcamera.org/api/1.1/series/5480/?format=api", "web_url": "https://patchwork.libcamera.org/project/libcamera/list/?series=5480", "date": "2025-10-07T18:17:42", "name": "ipa: libipa: Introduce V4L2Params", "version": 5, "mbox": "https://patchwork.libcamera.org/series/5480/mbox/" } ], "comments": "https://patchwork.libcamera.org/api/covers/24568/comments/", "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 AF391BF415\n\tfor <parsemail@patchwork.libcamera.org>;\n\tTue, 7 Oct 2025 18:17:57 +0000 (UTC)", "from lancelot.ideasonboard.com (localhost [IPv6:::1])\n\tby lancelot.ideasonboard.com (Postfix) with ESMTP id DD89B6B5F3;\n\tTue, 7 Oct 2025 20:17:55 +0200 (CEST)", "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 4541D69367\n\tfor <libcamera-devel@lists.libcamera.org>;\n\tTue, 7 Oct 2025 20:17:53 +0200 (CEST)", "from [192.168.1.102] (93-61-96-190.ip145.fastwebnet.it\n\t[93.61.96.190])\n\tby perceval.ideasonboard.com (Postfix) with ESMTPSA id 5A17D63F;\n\tTue, 7 Oct 2025 20:16:19 +0200 (CEST)" ], "Authentication-Results": "lancelot.ideasonboard.com; dkim=pass (1024-bit key;\n\tunprotected) header.d=ideasonboard.com header.i=@ideasonboard.com\n\theader.b=\"m4f3NgjT\"; dkim-atps=neutral", "DKIM-Signature": "v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com;\n\ts=mail; t=1759860979;\n\tbh=RfNE3uiZUlwYembciDkX/ONfqCMZ9ddMWnkEaWcaNSc=;\n\th=From:Subject:Date:To:Cc:From;\n\tb=m4f3NgjTN80Gcl2SiGbEepurjLeW4W6YED1ZgpKMP3dyGVrcBwHn3fTOqXKKhbts5\n\tAlEDIsIPlvUs69Fr5FUyDNvTOC9VrAuC5iUPpmWQPLEuUC0VCPmBbrNIN7TqYnt0qP\n\tl8ef1P6DWboqjDsN4mTR0asTEscgvsAftM33MIF8=", "From": "Jacopo Mondi <jacopo.mondi@ideasonboard.com>", "Subject": "[PATCH v5 0/5] ipa: libipa: Introduce V4L2Params", "Date": "Tue, 07 Oct 2025 20:17:42 +0200", "Message-Id": "<20251007-v4l2-params-v5-0-8db451a81398@ideasonboard.com>", "MIME-Version": "1.0", "Content-Type": "text/plain; charset=\"utf-8\"", "Content-Transfer-Encoding": "7bit", "X-B4-Tracking": "v=1; b=H4sIAEZZ5WgC/3XMwW4CIRSF4VcxrMVwL5dh6Krv0XTBDJdKooOBh\n\trQx8+5FF602uvxPcr6zqFwSV/GyOYvCLdWUlx5muxHz3i8fLFPoLVChUSM62eiA8uSLP1YZCL0\n\t3zrEdveiPU+GYvq7a23vvfaqfuXxf8QaX9bHTQCqpSVmr4zS4GF9TYF/zMmVfwm7OR3HhGv4RD\n\toZ7AjthByILHAbS5gmhbwj8R+hOMAOQHXGGiZ8Q9EuAUnBPUCfGiBNZ61CZR8S6rj/xSIn8dgE\n\tAAA==", "X-Change-ID": "20250829-v4l2-params-d42aa599e78a", "To": "libcamera-devel@lists.libcamera.org", "Cc": "Jacopo Mondi <jacopo.mondi@ideasonboard.com>, \n\tAntoine Bouyer <antoine.bouyer@nxp.com>, \n\tLaurent Pinchart <laurent.pinchart@ideasonboard.com>", "X-Mailer": "b4 0.14.2", "X-Developer-Signature": "v=1; a=openpgp-sha256; l=4238;\n\ti=jacopo.mondi@ideasonboard.com; h=from:subject:message-id;\n\tbh=RfNE3uiZUlwYembciDkX/ONfqCMZ9ddMWnkEaWcaNSc=;\n\tb=owEBbQKS/ZANAwAKAXI0Bo8WoVY8AcsmYgBo5VlPD4e5wh2Th34kvuWj5W2RRNnskhMR85ma8\n\tuV2hzuibkuJAjMEAAEKAB0WIQS1xD1IgJogio9YOMByNAaPFqFWPAUCaOVZTwAKCRByNAaPFqFW\n\tPCmcD/9AhiAKM+l2OQgr2NtFcoeYP2DUC5R069jJ3rItjolyq735QgST2VLExvoYdGXvvaFcdV3\n\tl0jjeEdapHVPgvK9/wABsRgzTgf37IcuIJ6dwX8stAmF8qFPACuvMJHZfGt9ZDSyKbQB1NHaXBU\n\t11WnM2o/eDUcsOc16uqGz5/Q5fyo1TSTzeNpWs0DzCZmVj+bqShvw8rGyd+MLuThHC2itUxBdRN\n\tZ5WF5lNm2lGgyck0mbreGRvPZ5LllQ4aoJC9WcI3XR6qE4tjDoVPl272fj00pe2/f2V0SnAhRpq\n\tcL46IeuL6b9GY1HKU017WVGM30C47EZclVnWSksEU02eB62OFQgdlgI9qeZwbzQOngz5H3bI+Cx\n\tM1WeYmd73l670j88NukVMXSXvA9VjOuEFxMPA6BIHCdmf12HjJWtd3cr2B7uM2dVUZHXTliMT57\n\tVX/Bh/ZqOtUc9xV47INHwnGlhavbBRV0C29Ml+UZ8pFsm6VgzJ29YNSFP+Ut7SJsqGI5932RVrG\n\t1ppa/V2y9I/2tuJDPVlqTUeGQQEOMhN7Ec7Zxje08mdwqw+Sm4wTDLnCFBXQRQXCI2nBAg6ikSJ\n\tRjyubzaY108XvifcqQoU3nD+b80jz6rKApQ227Tg3weOiMp7l4M6xTZsn5s8++G04GJ/Lrosn7j\n\t/5LJjUdjS+8KgnA==", "X-Developer-Key": "i=jacopo.mondi@ideasonboard.com; a=openpgp;\n\tfpr=72392EDC88144A65C701EA9BA5826A2587AD026B", "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>", "Errors-To": "libcamera-devel-bounces@lists.libcamera.org", "Sender": "\"libcamera-devel\" <libcamera-devel-bounces@lists.libcamera.org>" }, "content": "With the introduction of v4l2-isp.h in the Linux kernel currently in\nprogress:\nhttps://lore.kernel.org/all/20251007-extensible-parameters-validation-v6-0-5f719d9f39e5@ideasonboard.com/\n\nthe MaliC55 ISP driver at version in v11 has been ported to use a\nparameters format compatible with the one defined by v4l2 extensible\nparameters:\nhttps://lore.kernel.org/all/20250714-c55-v11-0-bc20e460e42a@ideasonboard.com/\n\nThis series\n1) Imports v4l2-isp in libcamera\n2) Update the Mali C55 header and IPA to compile with v11 of the patch\n series that introduces MaliC55 support in Linux\n3) Introduces V4L2Params by generalizing RkISP1Params\n4) Ports the Mali C55 IPA to use the newly introduced V4L2Params\n\nTested on rkisp1 and rzv2h\n\nSigned-off-by: Jacopo Mondi <jacopo.mondi@ideasonboard.com>\n---\nChanges in v5:\n- Update to v6 of v4l2 isp\n- Import linux/stddef.h instead of re-defining __counted_by()\n- Properly memset the whole mali-c55 buffer in the transitory patch\n before MaliC55Params introduction\n\nChanges in v4:\n- Mark RkISP1ParamBlock final\n- Fix code examples as suggested by Barnabas\n\nChanges in v3:\n- Fix Mali-C55 and re-work RkISP1\n The Mali and RkISP1 IPA have a different requirements:\n\n\tstruct mali_c55_params_awb_gains {\n\t\tstruct v4l2_params_block_header header;\n\t\t__u16 gain00;\n\t\t__u16 gain01;\n\t\t__u16 gain10;\n\t\t__u16 gain11;\n\t};\n\n\tstruct rkisp1_ext_params_awb_gain_config {\n\t\tstruct rkisp1_ext_params_block_header header;\n\t\tstruct rkisp1_cif_isp_awb_gain_config config;\n\t} __attribute__((aligned(8)));\n\n The RkISP1 IPA needs to support legacy and extensible parameter\n formats, and wants to operate on 'struct rkisp1_cif_isp_' basically\n discarding the header.\n\n The Mali IPA (and all other IPA compatible with v4l2-isp) operates on\n the whole structure and do not need to discard the header.\n\n Rework V4L2ParamsBlock to return a Span<> matching the whole structure\n (header included) to support Mali correctly.\n\n This means the RkISP1ParamsBlock derived class has to override all the\n dereference operators to discard the header and allow the IPA to work\n with both the legacy and extensible formats.\n\n Tested with Mali C55, RkISP1 in extensible and legacy modes.\n\n- Link to v2: https://lore.kernel.org/r/20250916-v4l2-params-v2-0-764471ed6435@ideasonboard.com\n\nChanges in v2:\n- Address Barnabas' reviwe that allows to remove the block() overload in\n MaliC55\n- Link to v1: https://lore.kernel.org/r/20250829-v4l2-params-v1-0-340773fb69ff@ideasonboard.com\n\n---\nJacopo Mondi (5):\n include: linux: Add stddef.h\n include: linux: Add v4l2-isp.h\n ipa: Update Mali C55 header file and adjust IPA\n ipa: libipa: Introduce V4L2Params\n ipa: mali-c55: Introduce MaliC55Params\n\n include/linux/mali-c55-config.h | 161 +++-----------------\n include/linux/media/v4l2-isp.h | 82 +++++++++++\n include/linux/stddef.h | 75 ++++++++++\n src/ipa/libipa/meson.build | 2 +\n src/ipa/libipa/v4l2_params.cpp | 254 ++++++++++++++++++++++++++++++++\n src/ipa/libipa/v4l2_params.h | 142 ++++++++++++++++++\n src/ipa/mali-c55/algorithms/agc.cpp | 87 +++++------\n src/ipa/mali-c55/algorithms/agc.h | 14 +-\n src/ipa/mali-c55/algorithms/algorithm.h | 2 +-\n src/ipa/mali-c55/algorithms/awb.cpp | 64 ++++----\n src/ipa/mali-c55/algorithms/awb.h | 10 +-\n src/ipa/mali-c55/algorithms/blc.cpp | 20 +--\n src/ipa/mali-c55/algorithms/blc.h | 3 +-\n src/ipa/mali-c55/algorithms/lsc.cpp | 58 +++-----\n src/ipa/mali-c55/algorithms/lsc.h | 8 +-\n src/ipa/mali-c55/mali-c55.cpp | 19 +--\n src/ipa/mali-c55/module.h | 3 +-\n src/ipa/mali-c55/params.h | 83 +++++++++++\n src/ipa/rkisp1/params.cpp | 93 +-----------\n src/ipa/rkisp1/params.h | 175 ++++++++++++----------\n utils/update-kernel-headers.sh | 2 +\n 21 files changed, 881 insertions(+), 476 deletions(-)\n---\nbase-commit: f0f2aca56611bf9430eb6edc23e9bd55cf96a26d\nchange-id: 20250829-v4l2-params-d42aa599e78a\n\nBest regards," }