{"id":26291,"url":"https://patchwork.libcamera.org/api/1.1/covers/26291/?format=json","web_url":"https://patchwork.libcamera.org/cover/26291/","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":"<20260313-mali-cru-v5-0-48f93e431294@ideasonboard.com>","date":"2026-03-13T16:14:34","name":"[v5,0/7] libcamera: mali-c55: Add support for memory-to-memory","submitter":{"id":143,"url":"https://patchwork.libcamera.org/api/1.1/people/143/?format=json","name":"Jacopo Mondi","email":"jacopo.mondi@ideasonboard.com"},"mbox":"https://patchwork.libcamera.org/cover/26291/mbox/","series":[{"id":5830,"url":"https://patchwork.libcamera.org/api/1.1/series/5830/?format=json","web_url":"https://patchwork.libcamera.org/project/libcamera/list/?series=5830","date":"2026-03-13T16:14:34","name":"libcamera: mali-c55: Add support for memory-to-memory","version":5,"mbox":"https://patchwork.libcamera.org/series/5830/mbox/"}],"comments":"https://patchwork.libcamera.org/api/covers/26291/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 8E735BE086\n\tfor <parsemail@patchwork.libcamera.org>;\n\tFri, 13 Mar 2026 16:14:47 +0000 (UTC)","from lancelot.ideasonboard.com (localhost [IPv6:::1])\n\tby lancelot.ideasonboard.com (Postfix) with ESMTP id B7D97626FF;\n\tFri, 13 Mar 2026 17:14:46 +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 B9BBD6261B\n\tfor <libcamera-devel@lists.libcamera.org>;\n\tFri, 13 Mar 2026 17:14:44 +0100 (CET)","from [192.168.224.131] (unknown [37.159.122.93])\n\tby perceval.ideasonboard.com (Postfix) with ESMTPSA id 016BAE70;\n\tFri, 13 Mar 2026 17:13:34 +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=\"OM25XFJm\"; dkim-atps=neutral","DKIM-Signature":"v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com;\n\ts=mail; t=1773418415;\n\tbh=pY/298FJWxwd+7TPeE8LrvUI/70Yk4w1YM2NFg5uHZs=;\n\th=From:Subject:Date:To:Cc:From;\n\tb=OM25XFJmtp9hCWNQDaarBHt1mDwlygtzoHbulDoxIInOkm2zdUHghztsO+OCO9X0O\n\tKwEr36DWXFgrNeSzVk9dG7m6A2ODQZ7lFhBSXkeFVIqgfOO1U3CLBjOUAWVZt2BE63\n\t7WstnVziyO40rCzqQ2Y3oEem1c7JlNne+7Y/SkaA=","From":"Jacopo Mondi <jacopo.mondi@ideasonboard.com>","Subject":"[PATCH v5 0/7] libcamera: mali-c55: Add support for memory-to-memory","Date":"Fri, 13 Mar 2026 17:14:34 +0100","Message-Id":"<20260313-mali-cru-v5-0-48f93e431294@ideasonboard.com>","MIME-Version":"1.0","Content-Type":"text/plain; charset=\"utf-8\"","Content-Transfer-Encoding":"7bit","X-B4-Tracking":"v=1; b=H4sIAOo3tGkC/3XOTQrCMBAF4KtI1kaSSaupK+8hLvIzowFtJNGil\n\tN7dKAhZtMs3M99jRpYxBcxsvxpZwiHkEPsS2vWKuYvpz8iDL5mBgFaCaPnNXAN36ckRJJA2Vil\n\tAVs7vCSm8flXHU8mXkB8xvX/Ng/xOZ0oGyQX3WlrbEuFOmUPwaHLsbTTJb1y8sW/XAJWXovJQP\n\tMK2AemxrO2CV7XvKq+KJ+qIhGqEtt2Cb/5+K5RUlW+Kd8J31mnnNc39P03TB27545hnAQAA","X-Change-ID":"20251205-mali-cru-e212f8ab332e","To":"Daniel Scally <dan.scally@ideasonboard.com>, \n\tlibcamera-devel@lists.libcamera.org","Cc":"Jacopo Mondi <jacopo.mondi@ideasonboard.com>, =?utf-8?b?QmFybmFiw6Fz?=\n\t=?utf-8?q?_P=C5=91cze?= <barnabas.pocze@ideasonboard.com>","X-Mailer":"b4 0.14.3","X-Developer-Signature":"v=1; a=openpgp-sha256; l=2442;\n\ti=jacopo.mondi@ideasonboard.com; h=from:subject:message-id;\n\tbh=pY/298FJWxwd+7TPeE8LrvUI/70Yk4w1YM2NFg5uHZs=;\n\tb=owEBbQKS/ZANAwAKAXI0Bo8WoVY8AcsmYgBptDfy2MwjnzZfIykZj1A4JveIup4wegyBB/yra\n\t5wl3TeF9WyJAjMEAAEKAB0WIQS1xD1IgJogio9YOMByNAaPFqFWPAUCabQ38gAKCRByNAaPFqFW\n\tPD7READEEUwbt68IhDQiQs9xBY05hKRHgOfo5oSDFQHbGAo5DY7TKer0jdf/SUH3Muia3pss6EI\n\tm6RrIokeuTAGjyd9+a6eqzRVoZztHk3oxE4Ev01soaB4+5FOx1yvbTrjhN4OOOlakxO6N5OyK/3\n\tvVD3tyfx3eJ0pqEU7N5U17k8eKql3XeXn2rKNGP3mLcTXMrqXlpSuz257kLwtDb5Nl6gNAIeQgB\n\tmx+mLoxPxqdn7opS2Aq0ZrEZSXr/YFzuBQ3PWhYJqJb310mY4zU5Cnjt+XE4Wyz3PIeU3MH7o4j\n\tQGdyJBAFK5812A/XwHuOtsHezJsQFr1AWlWFuCda5jaJUvIJ1DBoCpALX8mg4vewddIBl0mgXsl\n\tW9j3KufXAfTL1mJIDrMw94iWM8PZMc/AJqpbdJSmwTg2wvqxpaqDpRotgeQuzHOGnjOd+Gn1HrN\n\tlCf7aihtPtYrgA1juIbbzoZ4tn1hrQ8Co5TtRDYkdqkJPSe6HWehy59f9ktuKVswG775s/pGUiK\n\tP5dcZsrRYA4fv5J2uPSsaBehUyEi+QBRFxuVeJ0gKSHm/+X+PsFarr7pkrwfulf4NIFXmegXBzm\n\tgXYaYMCknBMPF7WJKvRWSBUiC8RCcUK4VTDlGx+FsS6ZV0ew4/aalA1l+WSq7wxZ09pEgSjvvs7\n\tgIaSiM4RyhiMEtg==","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":"Add support for m2m camera operations in the mali-c55 pipeline handler.\n\nThe series targets SoCs like the Renesas RZ/V2H(P) one where the\nMali-C55 ISP is integrated in m2m mode. The CSI-2 receiver (CRU) saves\nimages to memory and the ISP is fed through a dedicated DMA engine that\nprovides memory interfacing capabilities.\n\nThe series starts by adding support for the RZG2LCRU class (named after\nthe media device name) and then plumbs memory-to-memory operations in\nthe pipeline handler.\n\nTested on RZ/V2H(P) EVK with imx708 camera sensor.\n\nDan, could you re-test with Inline mode please ?\nI should have collected your fix that restored proper operations with\nInline.\n\nSigned-off-by: Jacopo Mondi <jacopo.mondi@ideasonboard.com>\n---\nChanges in v5:\n- Use overloaded std::visit when possible\n- Adjust indentation\n\nChanges in v4:\n- Move the overloaded visitor helper to utils.h\n\nChanges in v3:\n- Drop dynamic polymorphism and use overloaded visitor in\n  MaliC55CameraData. The result is neater in my opinion.\n- Address Barnabas' comments I missed in v2\n\nChanges in v2:\n- Almost a complete rework of the CameraData which is now a class\n  hierarchy. I'm not sure the result is that much cleaner, but hey, I'm\n  using templates and pattern with weird names, so it ought be better\n  for sure\n\n---\nDaniel Scally (3):\n      libcamera: mali-c55: Add RZG2LCRU class\n      libcamera: mali-c55: Register memory input camera\n      libcamera: mali-c55: Implement capture for memory-to-memory\n\nJacopo Mondi (4):\n      libcamera: utils: Add overloaded visitor helpers\n      libcamera: mali-c55: Split TPG and Inline camera handling\n      libcamera: mali-c55: Configure camera in memory-to-memory\n      libcamera: mali-c55: Fix sensor size computation\n\n include/libcamera/base/utils.h                |   7 +\n src/libcamera/base/utils.cpp                  |  35 ++\n src/libcamera/pipeline/mali-c55/mali-c55.cpp  | 623 ++++++++++++++++++++------\n src/libcamera/pipeline/mali-c55/meson.build   |   3 +-\n src/libcamera/pipeline/mali-c55/rzg2l-cru.cpp | 260 +++++++++++\n src/libcamera/pipeline/mali-c55/rzg2l-cru.h   |  73 +++\n src/libcamera/pipeline/virtual/virtual.cpp    |  10 +-\n 7 files changed, 867 insertions(+), 144 deletions(-)\n---\nbase-commit: 02277d4c1a5ae7fee582f635936877435a12db64\nchange-id: 20251205-mali-cru-e212f8ab332e\n\nBest regards,"}