Message ID | 20250314-sebastianfricke-vcodec_manual_request_completion_with_state_machine-v1-0-5e277a3d695b@collabora.com (mailing list archive) |
---|---|
Headers | show
Return-Path: <linux-mediatek-bounces+linux-mediatek=archiver.kernel.org@lists.infradead.org> X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id C0335C282EC for <linux-mediatek@archiver.kernel.org>; Fri, 14 Mar 2025 13:30:25 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:Cc:To: Content-Transfer-Encoding:Content-Type:MIME-Version:Message-Id:Date:Subject: From:Reply-To:Content-ID:Content-Description:Resent-Date:Resent-From: Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:In-Reply-To:References: List-Owner; bh=TFP7XQ1cObdqQ6De6eSsgjYNzHKxK2Nt4AObjojPfNo=; b=3ArIZWslrhNW/p V/7RZJ8FbxCoWfZV1lFl66v1KPU47xIoxlAT42jNRVlz+mhbD/+rneYSbZLb2o6S9lBOv36O3o1qW 60Anj48L5wINqAe92kwVGHWtsBI4C+TlCLpChrrZSy78x7SABG49XdjBClJ9lAk6dJ9HP6TJyNMbv jjR+J/ZCZ3XQqCTUbEHCyzj/JMH/Fi9KL2TDBedRI9ViZe2qsvLDAYtqTViuu3Rl+cDb5AXqF36vj aTG1hDNFGD41SHRB8oslSW0SMlovKN3KIY8VT+Smf/rQRId6CNWTHCAXEYFexQqmuNI4g9KL2WHQZ 0985CYJeYYuXfZ/8l/AA==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1tt57I-0000000EHX2-3sIw; Fri, 14 Mar 2025 13:30:24 +0000 Received: from sender3-pp-f112.zoho.com ([136.143.184.112]) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1tt53x-0000000EGt1-43rF; Fri, 14 Mar 2025 13:26:59 +0000 ARC-Seal: i=1; a=rsa-sha256; t=1741958798; cv=none; d=zohomail.com; s=zohoarc; b=D4k3SKsVi5dF8Z3ZB4rjnk6FXSb8ROD01yQSVBAcAm46+r9Rk7SRAbIJ6MQv07q8S1LSSg8TXuJousZ8TmJq6zDyYryNfkab3SWxrsn4h6K/T1VJgnY22rigFDVRgFIKLyM3b0+7DZt6aSomlfBL7QV2ZG7ryXCeWXbBsVFzL9w= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1741958798; h=Content-Type:Content-Transfer-Encoding:Cc:Cc:Date:Date:From:From:MIME-Version:Message-ID:Subject:Subject:To:To:Message-Id:Reply-To; bh=TFP7XQ1cObdqQ6De6eSsgjYNzHKxK2Nt4AObjojPfNo=; b=ihm1Uo8exTE5IABlu3X5y8qdKU30rmWh6Ur83wSEQy7JNbyR5qb3uL5z0jIE3x45f5YpRfK+6honuCaYvUztaL1MQPzCZDmua5z7xcTFsSPUG8sLLPD2AxKUsPMjf1zYMKnySvLbECuitGVqK1XyPjFOlI7Q+pa5bAW79c3XMqw= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass header.i=collabora.com; spf=pass smtp.mailfrom=sebastian.fricke@collabora.com; dmarc=pass header.from=<sebastian.fricke@collabora.com> DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; t=1741958798; s=zohomail; d=collabora.com; i=sebastian.fricke@collabora.com; h=From:From:Subject:Subject:Date:Date:Message-Id:Message-Id:MIME-Version:Content-Type:Content-Transfer-Encoding:To:To:Cc:Cc:Reply-To; bh=TFP7XQ1cObdqQ6De6eSsgjYNzHKxK2Nt4AObjojPfNo=; b=e8HuVzn+uMJOmOW7EN341A6UjAQkT9ccnM/Tw2WnM/Wz7ZDoRNKTyETONJgq4Gsk +GcnhLxcvKVjru8HwuU4j1nJgqRx4JVIzTtqey3QO022T0sMu56+a9SRH+QKyqOH2uW EDC819E5xZUpFRcGzCQJJCEaa3KSEtWDFxpsqnRk= Received: by mx.zohomail.com with SMTPS id 1741958796725877.1323443038518; Fri, 14 Mar 2025 06:26:36 -0700 (PDT) From: Sebastian Fricke <sebastian.fricke@collabora.com> Subject: [PATCH 0/5] Add manual request completion to the MediaTek VCodec driver Date: Fri, 14 Mar 2025 14:26:25 +0100 Message-Id: <20250314-sebastianfricke-vcodec_manual_request_completion_with_state_machine-v1-0-5e277a3d695b@collabora.com> MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit X-B4-Tracking: v=1; b=H4sIAIEu1GcC/x2O0QqCQBBFf0X2uQVdy6JfiVim8ZpDutrOaoH47 y09HricezajiAI112IzEauoTCFDdSgM9xSesNJmNq50p7KunFU8SJNQ6KLwC3blqQX7kcJCg49 4L9DkeRrnASnL/EdS7zVRQh5xLwG2qRvH5+5SUnU0+WmO6OT7r7jd9/0HIUjRl5UAAAA= X-Change-ID: 20250312-sebastianfricke-vcodec_manual_request_completion_with_state_machine-6362c7f80a14 To: Sakari Ailus <sakari.ailus@linux.intel.com>, Laurent Pinchart <laurent.pinchart@ideasonboard.com>, Mauro Carvalho Chehab <mchehab@kernel.org>, Hans Verkuil <hverkuil@xs4all.nl>, Tiffany Lin <tiffany.lin@mediatek.com>, Andrew-CT Chen <andrew-ct.chen@mediatek.com>, Yunfei Dong <yunfei.dong@mediatek.com>, Matthias Brugger <matthias.bgg@gmail.com>, AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com> Cc: linux-media@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, kernel@collabora.com, Sebastian Fricke <sebastian.fricke@collabora.com>, Nicolas Dufresne <nicolas.dufresne@collabora.com>, Hans Verkuil <hverkuil@xs4all.nl> X-Mailer: b4 0.14.2 X-Developer-Signature: v=1; a=ed25519-sha256; t=1741958789; l=3501; i=sebastian.fricke@collabora.com; s=linux-media; h=from:subject:message-id; bh=Xp0Y8pHU3fv/bIXLAawK95MaSBrGEYjOs4pySFviY/w=; b=3QIJWz8aO21ikn7G/sTIYXAiWCA335VBVJ6d1vE+9/medWSofWgVGyuBgGZC7ZJa/b73S13ls ZkS/Y9WunT3BVM1lwJ4dQnDfWRlQ+VNg5hKS73rldUKBA7XZligWjVL X-Developer-Key: i=sebastian.fricke@collabora.com; a=ed25519; pk=pYXedPwrTtErcj7ERYeo/IpTrpe4QbJuEzSB52fslBg= X-ZohoMailClient: External X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250314_062658_111015_E6239DFF X-CRM114-Status: GOOD ( 21.57 ) X-BeenThere: linux-mediatek@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: <linux-mediatek.lists.infradead.org> List-Unsubscribe: <http://lists.infradead.org/mailman/options/linux-mediatek>, <mailto:linux-mediatek-request@lists.infradead.org?subject=unsubscribe> List-Archive: <http://lists.infradead.org/pipermail/linux-mediatek/> List-Post: <mailto:linux-mediatek@lists.infradead.org> List-Help: <mailto:linux-mediatek-request@lists.infradead.org?subject=help> List-Subscribe: <http://lists.infradead.org/mailman/listinfo/linux-mediatek>, <mailto:linux-mediatek-request@lists.infradead.org?subject=subscribe> Sender: "Linux-mediatek" <linux-mediatek-bounces@lists.infradead.org> Errors-To: linux-mediatek-bounces+linux-mediatek=archiver.kernel.org@lists.infradead.org |
Series |
Add manual request completion to the MediaTek VCodec driver
|
expand
|
This set introduces the manual request completion API by the author Hans Verkuil and implements it within the MediaTek VCodec driver. Why is this needed? The VCodec driver supports a hardware containing two separate cores, the CORE and the LAT, these are working in a serial manner without this series. This series solves two issues, the first being that the current code runs into a problem, that occurs when the last request object is unbound from the request, before the v4l2_ctrl_request_complete function is called, causing an implicit transition to the COMPLETE state. This issues has been found in applications which didn't attach the controls for the very first request (which is supposed to enable the driver to sniff out the correct formats, etc.). The second issue is that the VCodec driver can not utilize the full performance of both cores, when the LAT core has to wait for the CORE core to finishing processing the decode. Thus by enabling the LAT core to process the next bitstream, right after processing the last we can increase the performance of the driver. With the manual request completion API, we can separate the completion of the request objects of a request and from the completion of the request itself, which allows to send a new bitstream after the LAT core has processed the previous and while the CORE core decodes the previous bitstream, so both cores can work in a parallel manner, but while keeping the request alive during both steps. A new state machine for the VCodec driver ensures, that all necessary processing steps are handled in the correct order depending on the current step in the execution. This state machine has been added to each request to ensure that new requests do not alter the state of still ongoing requests. Additionally, this series adds a small patch to avoid trying to handle a scenario, which is not supported by the hardware and thus runs into a timeout. Signed-off-by: Sebastian Fricke <sebastian.fricke@collabora.com> --- Hans Verkuil (3): media: mc: add manual request completion media: vicodec: add support for manual completion media: mc: add debugfs node to keep track of requests Nicolas Dufresne (1): media: mtk-vcodec: Don't try to decode 422/444 VP9 Sebastian Fricke (1): media: vcodec: Implement manual request completion drivers/media/mc/mc-device.c | 30 +++++++++++++ drivers/media/mc/mc-devnode.c | 5 +++ drivers/media/mc/mc-request.c | 44 +++++++++++++++++- .../mediatek/vcodec/common/mtk_vcodec_cmn_drv.h | 13 ++++++ .../mediatek/vcodec/decoder/mtk_vcodec_dec.c | 4 +- .../mediatek/vcodec/decoder/mtk_vcodec_dec_drv.c | 52 ++++++++++++++++++++++ .../mediatek/vcodec/decoder/mtk_vcodec_dec_drv.h | 4 ++ .../vcodec/decoder/mtk_vcodec_dec_stateless.c | 52 ++++++++++++---------- drivers/media/test-drivers/vicodec/vicodec-core.c | 21 +++++++-- include/media/media-device.h | 9 ++++ include/media/media-devnode.h | 4 ++ include/media/media-request.h | 38 +++++++++++++++- 12 files changed, 244 insertions(+), 32 deletions(-) --- base-commit: f2151613e040973c868d28c8b00885dfab69eb75 change-id: 20250312-sebastianfricke-vcodec_manual_request_completion_with_state_machine-6362c7f80a14 Best regards,