{"id":23596,"url":"https://patchwork.libcamera.org/api/1.1/patches/23596/?format=json","web_url":"https://patchwork.libcamera.org/patch/23596/","project":{"id":1,"url":"https://patchwork.libcamera.org/api/1.1/projects/1/?format=json","name":"libcamera","link_name":"libcamera","list_id":"libcamera_core","list_email":"libcamera-devel@lists.libcamera.org","web_url":"","scm_url":"","webscm_url":""},"msgid":"<20250618124541.2340270-2-antoine.bouyer@nxp.com>","date":"2025-06-18T12:45:40","name":"[v2,1/2] pipeline: imx8-isi: Add constexpr for maximum pipeline and resize if needed","commit_ref":null,"pull_url":null,"state":"superseded","archived":false,"hash":"3846349ab1b835db9686bca1bd2b5b002530b36e","submitter":{"id":218,"url":"https://patchwork.libcamera.org/api/1.1/people/218/?format=json","name":"Antoine Bouyer","email":"antoine.bouyer@nxp.com"},"delegate":null,"mbox":"https://patchwork.libcamera.org/patch/23596/mbox/","series":[{"id":5228,"url":"https://patchwork.libcamera.org/api/1.1/series/5228/?format=json","web_url":"https://patchwork.libcamera.org/project/libcamera/list/?series=5228","date":"2025-06-18T12:45:39","name":"pipeline: imx8-isi: Add multicamera support","version":2,"mbox":"https://patchwork.libcamera.org/series/5228/mbox/"}],"comments":"https://patchwork.libcamera.org/api/patches/23596/comments/","check":"pending","checks":"https://patchwork.libcamera.org/api/patches/23596/checks/","tags":{},"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 9369ABDE6B\n\tfor <parsemail@patchwork.libcamera.org>;\n\tWed, 18 Jun 2025 12:44:46 +0000 (UTC)","from lancelot.ideasonboard.com (localhost [IPv6:::1])\n\tby lancelot.ideasonboard.com (Postfix) with ESMTP id B3FC868DCE;\n\tWed, 18 Jun 2025 14:44:44 +0200 (CEST)","from AM0PR83CU005.outbound.protection.outlook.com\n\t(mail-westeuropeazlp170100001.outbound.protection.outlook.com\n\t[IPv6:2a01:111:f403:c201::1])\n\tby lancelot.ideasonboard.com (Postfix) with ESMTPS id 49F9668DC9\n\tfor <libcamera-devel@lists.libcamera.org>;\n\tWed, 18 Jun 2025 14:44:40 +0200 (CEST)","from DB9PR04MB9817.eurprd04.prod.outlook.com (2603:10a6:10:4f0::16)\n\tby PAXPR04MB8272.eurprd04.prod.outlook.com (2603:10a6:102:1c1::11)\n\twith Microsoft SMTP Server (version=TLS1_2,\n\tcipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8857.19;\n\tWed, 18 Jun 2025 12:44:38 +0000","from DB9PR04MB9817.eurprd04.prod.outlook.com\n\t([fe80::144:cb06:336d:abb3]) by\n\tDB9PR04MB9817.eurprd04.prod.outlook.com\n\t([fe80::144:cb06:336d:abb3%4]) with mapi id 15.20.8835.027;\n\tWed, 18 Jun 2025 12:44:38 +0000"],"Authentication-Results":["lancelot.ideasonboard.com; dkim=pass (2048-bit key;\n\tunprotected) header.d=nxp.com header.i=@nxp.com header.b=\"lay0aaMq\";\n\tdkim-atps=neutral","dkim=none (message not signed)\n\theader.d=none;dmarc=none action=none header.from=nxp.com;"],"ARC-Seal":"i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none;\n\tb=TktNAgGlkYAcg9PkR8K2N/x7QGarGekBvZq/KievuGgdD1TvV/7zoD7LPxaYm7aoFeIS0WrpEYRBiCsU00gwdtFInp/ikd/5fJpsTDjyhbIlLcW+3MtSIWxtG06yThmVTBzahpe3XXhigIN0nLyfUeI//n4IzhVPlRuGGkWQKjuN8d7tb7WcqQh6OhoX25yrwGYA7CVDd97OEXCVnZPlV7wIBF6bgrAROIvvFmKZpJ65oIl10P9oBY8ki0ugrsMR2JydlbDjJ0X0oL3LESED9Sc6PKBAmbP8py7bAWqB0oGxyAC4xbd6G2C9p2e7QCuIFykgCnhQXQbZ2aGnpJp+cQ==","ARC-Message-Signature":"i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com;\n\ts=arcselector10001;\n\th=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1;\n\tbh=hTEF7pYw5YdqXJ8zarRLMx0KlhnsLJL0ZKMHluXPDb0=;\n\tb=UJKItFMw081jiXZpwEXUHveHg7jeJ3/fTfUvP2RPRG5zdV9sgjy5Q+zArmOWHYng1rbaUqo7WM8fmJi74bj3IEJuUnOZRtvlgmIl3RQF03EvrD2z8LkiJKPARrs6Q3udxR0JS2m96AHp76PUMJEBEL0VFaTL5oM5QeV1WycQFJqV73XpYar9H5YTXd/CRZBW8eB8HD/joYc2r5uHrAghQP6hSefu0cZNMb9OGFMr2cMdboq4G7Wd3CGBoJuVPvhJkyxrKAAMU8RpRhQ6dfnSyDDGEoa/JBpj/nxa9hmG4hihbEMhmByArfoFhxe48zFiRA+FfHUEdiyc9cXwTwBkHg==","ARC-Authentication-Results":"i=1; mx.microsoft.com 1; spf=pass\n\tsmtp.mailfrom=nxp.com; dmarc=pass action=none header.from=nxp.com;\n\tdkim=pass header.d=nxp.com; arc=none","DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/relaxed; d=nxp.com; s=selector1;\n\th=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck;\n\tbh=hTEF7pYw5YdqXJ8zarRLMx0KlhnsLJL0ZKMHluXPDb0=;\n\tb=lay0aaMqi+ptx/o3sglt9eGyRCQLMtigL/DuH5X3mENfXO58xaqhIvPbTK57fpUTSDjhjRDfBilQfl/06NL71khQOpB7E+lm1mB0EYWzgXaR9GXv7mNgiUt/+KbB8ZK/6ghg5dgu+Bx+wpm6jaLLb0ucStcouUxVkPLTjLtjGHiYCN/sHS4Cr0ZbCsZnrhdDT6sdYRwN/tShaZMCdeqgXlCn2X4xVx7wz7BWhI5HVX8EO+MSogkdx5e0INybVUtNKr4WssBE63bwSYQ0bUfmf3MPq9lcTZWJPJsOys65Uc6KhCIqZrlABQpJ1Nk2CcDw7fXOO+P6rR+PG77DcC2lBQ==","From":"Antoine Bouyer <antoine.bouyer@nxp.com>","To":"libcamera-devel@lists.libcamera.org","Cc":"julien.vuillaumier@nxp.com,\n\tAntoine Bouyer <antoine.bouyer@nxp.com>","Subject":"[PATCH v2 1/2] pipeline: imx8-isi: Add constexpr for maximum\n\tpipeline and resize if needed","Date":"Wed, 18 Jun 2025 14:45:40 +0200","Message-Id":"<20250618124541.2340270-2-antoine.bouyer@nxp.com>","X-Mailer":"git-send-email 2.34.1","In-Reply-To":"<20250618124541.2340270-1-antoine.bouyer@nxp.com>","References":"<20250618124541.2340270-1-antoine.bouyer@nxp.com>","Content-Transfer-Encoding":"8bit","Content-Type":"text/plain","X-ClientProxiedBy":"AM0PR02CA0106.eurprd02.prod.outlook.com\n\t(2603:10a6:208:154::47) To DB9PR04MB9817.eurprd04.prod.outlook.com\n\t(2603:10a6:10:4f0::16)","MIME-Version":"1.0","X-MS-PublicTrafficType":"Email","X-MS-TrafficTypeDiagnostic":"DB9PR04MB9817:EE_|PAXPR04MB8272:EE_","X-MS-Office365-Filtering-Correlation-Id":"0d8ef6e3-6b64-4498-3ab3-08ddae65e2ef","X-MS-Exchange-SenderADCheck":"1","X-MS-Exchange-AntiSpam-Relay":"0","X-Microsoft-Antispam":"BCL:0;\n\tARA:13230040|376014|52116014|366016|1800799024|38350700014; ","X-Microsoft-Antispam-Message-Info":"wWLEqTc5h7i/2mCVyU/XEnSXjQd1r+K6xJeEvXGh0AJWnUaPeQQG2/C6c1ozuusjYc6VVkVdFddgEnnsVtNG/uuRLEWGz4cv6rNwfwLg6JBwQf2U9rVxvGfP6Q5AyIwzT6umDYcOtLyVPyiuGAb59xo0awWG5IbiHOzfxt7iDtIwFHZYuVBALf8+DzQx5m5VXnSW19vgnPZ4NmXsFKQq1qdPW02puFcedJ+i18vTP3C/3hF8ijCuo2iD0fvAHUj4B8EhXDyN3PdGbBphtIpcdq2zTu2sospV4+gmQI5mRnWqQqR76FBHF0r9Lrr2vvCeks6k4RsW4dAMy0FYS2hAGukrBe4d+ktMiupJKBVjkURTzM2V3t2jTJ81+jG/vExq2aU7j2CdhBVm2wFIWKD1MookCATCzeCi78/giIsVIDY4Sf/nhHQ0UMnFnPdhJ/tmVVquPHIt3pOcEF+8ZeeAVaJdZWMhOwHubP/8XK05rPkxvQeT44oddPERM7BxxY4AybFs6gqKHS2lWSxC4r25/GsftXLK/jc5L/VgB9p/vlVir7yDe4joL3d2nB4E8fvbNX7K91K1oVOdSqCML4P7QqfF5aDuTWMMh1t02QJJEK47Fzo+2xzPz9hVegY3jwnxy9ingA7I4/2/XRYjpu4V3WXb2xJJoOobwSocymuJBy4DeT0s6ScYMUOr4aaG3FyY1Z6aoumD5X88rzu+xtjlrZrw8YcvB9ePQjZg6NuclkI67uWxcwRQ66ddmcapvCyz6XeIULJOqGCdTYp4ANgXCrNIrQw1t2ZfIRw1lK05JvLMcMLCag6ZPVF3R0YRGTJ2fMVV4aaeilaiYe1gy+ODh3PU3K2hKHu/JFR6q8uEnkDNGcZbGVDHdRgFKnTAamw+fUmQ5jb9g5XLTGlClTod/SFj7HqN5Nm8Cw2kvwmJv2uRSLcHjkxsCVfUFNi5pDG6xME9fbHJsonBKwhWj9Zdv5jjrDfylMTgRN+UWSIbxso8zAvm1gaN1g6sHurZE03RS5se6Um5uRFk43GCWGlwgBP+3IwTMm/DGGof9Y8LhzvC81HpkNyFeUBjVZDv0CyQaUHBE5gbF2Fj5TC1pxPPQAvIAOUMq7CLPnuvNcTfPfdbIa/pR0n0EK76vvZQWOV3aMGQXE5aeM0zC/bhIUwTopmGlMdIPMehFe1FwS4WhpCR3xVw3FY3EEZLHcARRv2Xare0mCC2eU1ovZGtOrxfM3IMoP0ZdfqJQwOTi1NfFq3H9NDruG1nW2Qw8OytHarGK24MfWMgA9cKPYabDUEIYwfpnT+uvcmaK3OxrfZXl/B47k76c7EYQhS2NqY3WirvpTA6uLcRbjoqy1NDzB8kXECChLdBWV8fpIp9hBT4Z4jfd8bPpmVrXJE5Hzs4ng65ePzbNpe4OIgUXap5bAu3FZh1kDdJuy35pI+bS1zRE29W0a8brBk1Iut370Ln9ftEaEM95QDnoDRzh50royqvyA==","X-Forefront-Antispam-Report":"CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:;\n\tIPV:NLI; SFV:NSPM; H:DB9PR04MB9817.eurprd04.prod.outlook.com; PTR:;\n\tCAT:NONE; \n\tSFS:(13230040)(376014)(52116014)(366016)(1800799024)(38350700014);\n\tDIR:OUT; SFP:1101; ","X-MS-Exchange-AntiSpam-MessageData-ChunkCount":"1","X-MS-Exchange-AntiSpam-MessageData-0":"TRwZ0jox/JKvHnc0dCJ3f4v5uEF1mv349gNeJ1+vp6MFbmak5kxIiFxGC1tiME0WoG9ejLxnP3j8Kd136/kXeVoVYU1W/nWn8lf/HyYvkACt/D/+zkjzj5dmzLzkq+BHQm3ACA7FxKIrB49S4xF69wOuI7QZoeRduL46itbFgifz7jgTD5PGTelc7QZ/mJAwdcvsp7bu+O4oFDP+bOvaIJrhC338SBZ96rkJCtbf4UowpkhKl0fXvEUfgR3ux1/To2T3QLsAJFcKk19vtea/k8e1FtG5BmY8tiktvnyPRxUqHwSZ/paJ8h4+NbzL1k3HzGik07gMv2l0GWErLfWHvyI/oAU987Od+e2hdP3wFn1afqyRpYTloFzvmma3BDjgxgymMSLT5O+ouWMb1vHwTpuynrUka54swOSJtFPkC2RtKdIJgYwGNYMy3rgGuoxQDzf5j4Ij8A7F+o83RON2q41MMN2Q8AEYgfQR7LHttdcBvRAoEASvZRUd+WaLPcM0WkIdk6XPNhS3eUNgFKYWdushgCVnoEt1RFgnY8Tv8JBI/pEH40mGISzP+lHTs6fDq43SGc4zq/ZP12879Mll1O1dFoOmHclJR7sQp7l1/8lQqoODshbIs+XXvR2A1vzwG1tTXg5PVuqTex7GFiVNLi8OiudDpAoS2FW41J6U4dvWGpYjqQAdzWXPTT8UepyHVo2D28yNW69CJ3ENhMEjLAtRP2q7iyXlkkP8Pf5Tuhmlft83GeSp9XHVMQYWFjZ0YH7e6lwHapDogdYHdAY9aneBqxyrzvrXqi2Pj9b3IxkxFoT2R/xWPUv04GxaARDsPwM/Biyuuilso6KAZHUU616GaCi7rkqPEIYjKLf6yRc5+lQ46TSdS8O11fQ5LcdzhHeOpKdy55fburZPKhVoSUQthiaUbsGTLQ8Zteztbj2bUme6mFfBo3r6UjX3gOBPmC35/6rdswe8Bz9F02YPY2kyVs8iTHe11rsNYlrVjEL6GS6FU8CqDMg3+Mi4Zb/+63nLQXiT/bxYT9MEb3s9rVv5l6dvYtY+1jv4/8HIWZakz+Cm1CmZwIwE4a3H7dkQm4zyEYJhyH8SrT9XpZvGspeq0GxMMuiiSiur9Ydq2B/byKqQzwt469gpeRAVYO5YDhZh4aoHgg6sxFcoOCWCJB1qqeqK6RdYXR6TCLwlKXNoO/XyXbA1Z2Ri9+8SNk2MgJFAC90IJpNNzt4RM34Zj9ODYWQlUYh6BD1rMSSkHs7nwBvdkps+kpAriaha8Maz1KlATyiwjL44qIU9aYRQgLZS/BysXidjknySCuc6hCgl4htql8WJBO/fWJJrIFRibDAhWuFc2PrDuG7eZbOhbt1/w0n7vdPjyZem50BR3O3I/FRUaGF2lKccYd7b5iw1NThZvs6l4We7Kkd9hyRsY3e1O9r7KwB40yJ+WdTbFKwVTQIBnUqT3Wlaoiv7hGHUbZMjaG9EMngg4ZzaaHfOUR3aXFTzaqvy/YwSnAOjc0AfqPvsfeYbIghSeGlVbWTGiLB+zD9IArxDuIwA67MjJKNfpwwKJMsfjKQkHfMij+Er1osH1fEjJMFpjDR/TW6KA1BTTlhadOTParV7wkEz3g==","X-OriginatorOrg":"nxp.com","X-MS-Exchange-CrossTenant-Network-Message-Id":"0d8ef6e3-6b64-4498-3ab3-08ddae65e2ef","X-MS-Exchange-CrossTenant-AuthSource":"DB9PR04MB9817.eurprd04.prod.outlook.com","X-MS-Exchange-CrossTenant-AuthAs":"Internal","X-MS-Exchange-CrossTenant-OriginalArrivalTime":"18 Jun 2025 12:44:38.0302\n\t(UTC)","X-MS-Exchange-CrossTenant-FromEntityHeader":"Hosted","X-MS-Exchange-CrossTenant-Id":"686ea1d3-bc2b-4c6f-a92c-d99c5c301635","X-MS-Exchange-CrossTenant-MailboxType":"HOSTED","X-MS-Exchange-CrossTenant-UserPrincipalName":"vdbOCIsJ0Lz5mnj2S5nhBf1fDq+hRfOBm1ppoVTS/S6+/+yMVMG5ZzBOfJEDFy7YdwG0lsQbXQWOeoGV1Olgqw==","X-MS-Exchange-Transport-CrossTenantHeadersStamped":"PAXPR04MB8272","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":"This patch adds number of streams per camera as constructor parameter, and\nlimits stream count to 3. Some applications may need up to 3 streams for\npreview + capture + video record. Currently, imx8-isi pipeline only supports\nup to 2. Increase constant parameter to 3 to match these applications'\nrequirements.\n\nMinimum value between default value 3, and total amount of ISI's pipes is\nnow applied. For SOCs which only have 1 ISI pipe (ie i.MX93), available\nstream count becomes 1.\n\nSigned-off-by: Antoine Bouyer <antoine.bouyer@nxp.com>\n---\n src/libcamera/pipeline/imx8-isi/imx8-isi.cpp | 17 ++++++++++-------\n 1 file changed, 10 insertions(+), 7 deletions(-)","diff":"diff --git a/src/libcamera/pipeline/imx8-isi/imx8-isi.cpp b/src/libcamera/pipeline/imx8-isi/imx8-isi.cpp\nindex ecda426a6021..186b623df186 100644\n--- a/src/libcamera/pipeline/imx8-isi/imx8-isi.cpp\n+++ b/src/libcamera/pipeline/imx8-isi/imx8-isi.cpp\n@@ -40,14 +40,13 @@ class PipelineHandlerISI;\n class ISICameraData : public Camera::Private\n {\n public:\n-\tISICameraData(PipelineHandler *ph)\n+\t/* Maximum amount of streams (i.e. pipes) per camera. */\n+\tstatic constexpr unsigned int kNumStreams = 3;\n+\n+\tISICameraData(PipelineHandler *ph, unsigned int numStreams)\n \t\t: Camera::Private(ph)\n \t{\n-\t\t/*\n-\t\t * \\todo Assume 2 channels only for now, as that's the number of\n-\t\t * available channels on i.MX8MP.\n-\t\t */\n-\t\tstreams_.resize(2);\n+\t\tstreams_.resize(std::min(kNumStreams, numStreams));\n \t}\n \n \tPipelineHandlerISI *pipe();\n@@ -1052,8 +1051,12 @@ bool PipelineHandlerISI::match(DeviceEnumerator *enumerator)\n \t\t}\n \n \t\t/* Create the camera data. */\n+\t\t/*\n+\t\t * \\todo compute available pipes per camera instead of using\n+\t\t * pipes_.size() for multi cameras case.\n+\t\t */\n \t\tstd::unique_ptr<ISICameraData> data =\n-\t\t\tstd::make_unique<ISICameraData>(this);\n+\t\t\tstd::make_unique<ISICameraData>(this, pipes_.size());\n \n \t\tdata->sensor_ = CameraSensorFactoryBase::create(sensor);\n \t\tdata->csis_ = std::make_unique<V4L2Subdevice>(csi);\n","prefixes":["v2","1/2"]}