Received: by 2002:a05:7412:419a:b0:f3:1519:9f41 with SMTP id i26csp3743736rdh; Tue, 28 Nov 2023 02:39:46 -0800 (PST) X-Google-Smtp-Source: AGHT+IFu8BX8NPG+BEi0rd5t8QbKwjpnH4szkt0jXAyKB6LZY+7TXPS3oGrdgkyA1Gz53Z+ZcHVq X-Received: by 2002:a17:903:1d2:b0:1cf:ad96:10bd with SMTP id e18-20020a17090301d200b001cfad9610bdmr13064953plh.69.1701167985728; Tue, 28 Nov 2023 02:39:45 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1701167985; cv=none; d=google.com; s=arc-20160816; b=xh89tz1UMlOMklyjmsjwoJxwWX/kZ6QOzVkebO4WIYUVGbEcaT9HhDtLocCdhMV3zk 8cJNE0b5ftRxC3ZW4jM+H8x8vvwvw9sJ/EqbKSRgejtfkmP0gednAunGSyaLzgxtKosn GGuD6KmQ0HAsrLPhnHDynWDTkX5dvnLFg9GifpQRc3h6MNZgH4p55WYmgqma8hlgHuCO FOQJOnKGR/jyn1UJYR8K4ByU1cYI6XBtaMUMbLo3AXI4aN6cinOC6yLeI0JLqFcDHrM+ eoEFahwttAwFQ1F/nDqJT3nYuRe5kK7UEEPTgJby4dM+Ln9y8qRPe7ShlTi6LI58514h 8nnQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=+OFLW0iWOizQGUOpN1cGJG9mQqsxPoMdSoQY+3XNgcw=; fh=0FTStoj8hLD5Ov0Bm4oCkjH9r2k6J0/2qMhGyWtn1eM=; b=Fz2KdRYag4RIrZhvg9sZ5L0LOCkNkk76CyUevcgI+lVIB+jdNZTRgTOLYJHe+pJXMr DocloxGKb64DPnYZeUFlrKiWRvBwEJIRcnX8Lgd1eNfgyCjEX6clGXmG9FQ2zEBv8dUU /wsIJ7AlkCj1k4xhQm0WahFOL7J1LvxlrrK5V0c3b1X1tcyqlfYOOopOcHN7/F5MbGP4 Xp7ie8NKXtRdbLOtZElQ0FL6cpcGxBC6O5BgF3inzCxMB1UVtAjtrwL0HqTCrMeKBNJz ThybUa5CazIF/XBR9fqX8ow5g2eim073DyhJ8khp5Jf+l8HrjNJxZK3/BAQZqbcM92TW xJJQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=fPSIAFQe; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:8 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=collabora.com Return-Path: Received: from fry.vger.email (fry.vger.email. [2620:137:e000::3:8]) by mx.google.com with ESMTPS id z8-20020a1709027e8800b001cfdd2fe63csi2811157pla.312.2023.11.28.02.39.45 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 28 Nov 2023 02:39:45 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:8 as permitted sender) client-ip=2620:137:e000::3:8; Authentication-Results: mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=fPSIAFQe; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:8 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=collabora.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by fry.vger.email (Postfix) with ESMTP id 0716A80879D5; Tue, 28 Nov 2023 02:39:43 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at fry.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1344454AbjK1Kj1 (ORCPT + 99 others); Tue, 28 Nov 2023 05:39:27 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:50298 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234968AbjK1KjE (ORCPT ); Tue, 28 Nov 2023 05:39:04 -0500 Received: from madras.collabora.co.uk (madras.collabora.co.uk [46.235.227.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 6580F35AC; Tue, 28 Nov 2023 02:26:45 -0800 (PST) Received: from [100.122.216.38] (ec2-34-240-57-77.eu-west-1.compute.amazonaws.com [34.240.57.77]) (using TLSv1.3 with cipher TLS_AES_128_GCM_SHA256 (128/128 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) (Authenticated sender: benjamin.gaignard) by madras.collabora.co.uk (Postfix) with ESMTPSA id 1D0EF6607295; Tue, 28 Nov 2023 10:26:43 +0000 (GMT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=collabora.com; s=mail; t=1701167204; bh=wnu068ECaNnR7zM2tCS6WGVU5g0Vyny4l5k0cqi5/Gk=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=fPSIAFQe+6bLt14IZnT7Oq4e2qP9zCUUu1mEtQ5CevwcHsIFRBtsaLBWGMyrc8y90 evscUsbWNpKSG9kHvDOqeRl9iZUjmwzUgr9iKXjMG2EX0YcjrxnDZouGMEehWJe0Aa 61o7FxguyZkUx7b51F3pHeLokSiqjzszdNZrin3Abt2joXa4YXnuMFA5GJT0NKkNqH IZ8T6bEuS6RlUSmFer/Jqkr6Pnv4f66UiMYWNj5Q9r+T3pn4abktqtXVXAgtmb798l 5VbFKYCLbmeyOioDfpKiiYgsKC8QrpP75gwPYKYjqts7Eu39fSJQAtwESJQtClZpxT riuckDGEZN1qg== Message-ID: <995eb6c2-cc7f-4217-bc37-4ab1a32f36ee@collabora.com> Date: Tue, 28 Nov 2023 11:26:40 +0100 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH 07/55] media: imx8-isi: Stop abusing of min_buffers_needed field Content-Language: en-US To: Tomasz Figa Cc: Laurent Pinchart , hverkuil@xs4all.nl, mchehab@kernel.org, m.szyprowski@samsung.com, matt.ranostay@konsulko.com, linux-kernel@vger.kernel.org, linux-media@vger.kernel.org, linux-staging@lists.linux.dev, kernel@collabora.com, Shawn Guo , Sascha Hauer , Pengutronix Kernel Team , Fabio Estevam , NXP Linux Team References: <20231127165454.166373-1-benjamin.gaignard@collabora.com> <20231127165454.166373-8-benjamin.gaignard@collabora.com> <20231127170700.GC31314@pendragon.ideasonboard.com> <6fa1ec09-3e30-475e-9718-29d23586753e@collabora.com> From: Benjamin Gaignard In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on fry.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (fry.vger.email [0.0.0.0]); Tue, 28 Nov 2023 02:39:43 -0800 (PST) Le 28/11/2023 à 10:35, Tomasz Figa a écrit : > On Tue, Nov 28, 2023 at 6:31 PM Benjamin Gaignard > wrote: >> >> Le 27/11/2023 à 18:07, Laurent Pinchart a écrit : >>> Hi Benjamin, >>> >>> Thank you for the patch. >>> >>> On Mon, Nov 27, 2023 at 05:54:06PM +0100, Benjamin Gaignard wrote: >>>> 'min_buffers_needed' is suppose to be used to indicate the number >>>> of buffers needed by DMA engine to start streaming. >>>> imx8-isi driver doesn't use DMA engine and just want to specify >>> What do you mean, "doesn't use DMA engine" ? The ISI surely has DMA >>> engines :-) >> I have done assumption on drivers given if they use or dma_* functions. > I suspect the use of vb2_dma_sg_plane_desc() and > vb2_dma_contig_plane_dma_addr() may be more correlated to whether > there is a DMA involved or not. Usually V4L2 drivers don't really have > to deal with the DMA API explicitly, because the vb2 framework handles > most of the work. Unfortunately isn't not true either, for example verisilicon driver use these function but doesn't need DMA engine. I haven't found yet a 100% criteria to decide if driver use or not DMA engine so I plan to fix case by case given maintainers remarks. Regards, Benjamin > > Best regards, > Tomasz > >> I have considers that all PCI drivers are using DMA engine and >> I don't know the design for each drivers so I hope to get this information >> from maintainers and fix that in v2. >> If imx8-isi driver needs a minimum number of buffers before start streaming >> I will do a v2 and use min_dma_buffers_needed instead. >> >> Regards, >> Benjamin >> >>>> the minimum number of buffers to allocate when calling VIDIOC_REQBUFS. >>>> That 'min_reqbufs_allocation' field purpose so use it. >>>> >>>> Signed-off-by: Benjamin Gaignard >>>> CC: Laurent Pinchart >>>> CC: Mauro Carvalho Chehab >>>> CC: Shawn Guo >>>> CC: Sascha Hauer >>>> CC: Pengutronix Kernel Team >>>> CC: Fabio Estevam >>>> CC: NXP Linux Team >>>> --- >>>> drivers/media/platform/nxp/imx8-isi/imx8-isi-video.c | 2 +- >>>> 1 file changed, 1 insertion(+), 1 deletion(-) >>>> >>>> diff --git a/drivers/media/platform/nxp/imx8-isi/imx8-isi-video.c b/drivers/media/platform/nxp/imx8-isi/imx8-isi-video.c >>>> index 49bca2b01cc6..81673ff9084b 100644 >>>> --- a/drivers/media/platform/nxp/imx8-isi/imx8-isi-video.c >>>> +++ b/drivers/media/platform/nxp/imx8-isi/imx8-isi-video.c >>>> @@ -1453,7 +1453,7 @@ int mxc_isi_video_register(struct mxc_isi_pipe *pipe, >>>> q->mem_ops = &vb2_dma_contig_memops; >>>> q->buf_struct_size = sizeof(struct mxc_isi_buffer); >>>> q->timestamp_flags = V4L2_BUF_FLAG_TIMESTAMP_MONOTONIC; >>>> - q->min_buffers_needed = 2; >>>> + q->min_reqbufs_allocation = 2; >>>> q->lock = &video->lock; >>>> q->dev = pipe->isi->dev; >>>>