Received: by 2002:a05:7412:d8a:b0:e2:908c:2ebd with SMTP id b10csp685697rdg; Wed, 11 Oct 2023 02:37:22 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFh+bAoz+KelwdNa/Y8h1oHyo8Rwr4w8qEOV8CEIPgcXRlsOj6VKjIXC+SjbjVE+cc/m4tY X-Received: by 2002:a17:902:b710:b0:1c9:bf14:4f94 with SMTP id d16-20020a170902b71000b001c9bf144f94mr3029500pls.44.1697017042550; Wed, 11 Oct 2023 02:37:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1697017042; cv=none; d=google.com; s=arc-20160816; b=Nf4QlnkvSAaa32rfBzagiQdmz06FDx6PeVBGJ/t1vs82esexhlaVJaHuuwjVb+Qjfp wctgsMOaP94FMg+qWrajPO/v/DVYFU+++NKzl78jVjCdb3Dzj5wkbBI9NhoITl7vCAlS oQHxG7SaKm3SaBn4Ji1cNoHwfVaQPdSRhiJANkXNanw/XmmIP36C+w0wP3EqPHXcxRgS d4dh6AqZBf6DV+gkNQ8YCB/e9Yqt8uIF1dYNvT+QkUN/uMV5LGHa0cuChbl3NZJSxrrD 0Gwc1ARoK0CbgDxppKKe2JBwQ2yhkv6571WRwhYG3Iwpblusbxc/oKURKm0qAtV2kzMb KSYQ== 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; bh=Q4q6X4gIaWpnZrKyLrVc1fLreLMIAbf6tvRHXoPwnEw=; fh=rvfjkWKWQ7H3dxwU/Mrzlf1SBsZ3Tuo/EBElQFetDNM=; b=L3pRV4gOCfwnMRTGIfczVV80jj8ampw2Hx15VsKWo2Z9M8eu9w1x3znswps14ZEo/m QQo0ebT3wV3AfdynihUC8tHCwXfrFaVre+tNL9IgpFcEqrtqqQbW66Te6jUfDn+lVQow W4PyJPahzqvHSAdIANyXZnU9/M7yPh5oosUgNE7i2QIhV7kKm8BFem0B8ylRLuLhlGk6 E/6HAeQKZfvWH9xu0QfXkFyYQTgHHM4MH7uDU+B7Uvz43MBZaalW6depB3stopTU2cy8 Dyc13mwispUOmWbC/X0wjmwD6/q4VFEgRPrDyY7O3G45ocfURzZLookrtXiuoTDFrBOM zCjw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.31 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=xs4all.nl Return-Path: Received: from morse.vger.email (morse.vger.email. [23.128.96.31]) by mx.google.com with ESMTPS id kw15-20020a170902f90f00b001bbd0450af8si13094204plb.187.2023.10.11.02.37.22 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 11 Oct 2023 02:37:22 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.31 as permitted sender) client-ip=23.128.96.31; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.31 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=xs4all.nl Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by morse.vger.email (Postfix) with ESMTP id 550AF80E342C; Wed, 11 Oct 2023 02:37:19 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at morse.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1345663AbjJKJg4 (ORCPT + 99 others); Wed, 11 Oct 2023 05:36:56 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37508 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234314AbjJKJgx (ORCPT ); Wed, 11 Oct 2023 05:36:53 -0400 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C8D0CA4; Wed, 11 Oct 2023 02:36:51 -0700 (PDT) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 21E86C433CD; Wed, 11 Oct 2023 09:36:47 +0000 (UTC) Message-ID: <07237b8b-ecd2-4717-8eda-101e52edf60c@xs4all.nl> Date: Wed, 11 Oct 2023 11:36:46 +0200 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v10 11/54] media: videobuf2: Access vb2_queue bufs array through helper functions Content-Language: en-US, nl To: Benjamin Gaignard , mchehab@kernel.org, tfiga@chromium.org, m.szyprowski@samsung.com, ming.qian@nxp.com, ezequiel@vanguardiasur.com.ar, p.zabel@pengutronix.de, gregkh@linuxfoundation.org, nicolas.dufresne@collabora.com Cc: linux-media@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, linux-arm-msm@vger.kernel.org, linux-rockchip@lists.infradead.org, linux-staging@lists.linux.dev, kernel@collabora.com References: <20231003080704.43911-1-benjamin.gaignard@collabora.com> <20231003080704.43911-12-benjamin.gaignard@collabora.com> <954315b8-3e5c-4583-a904-d20fbd21aa3f@collabora.com> From: Hans Verkuil In-Reply-To: <954315b8-3e5c-4583-a904-d20fbd21aa3f@collabora.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=2.8 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RCVD_IN_SBL_CSS,SPF_HELO_NONE,SPF_PASS autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on morse.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 (morse.vger.email [0.0.0.0]); Wed, 11 Oct 2023 02:37:19 -0700 (PDT) X-Spam-Level: ** On 11/10/2023 11:32, Benjamin Gaignard wrote: > > Le 11/10/2023 à 10:44, Hans Verkuil a écrit : >> On 03/10/2023 10:06, Benjamin Gaignard wrote: >>> This patch adds 2 helpers functions to add and remove vb2 buffers >>> from a queue. With these 2 and vb2_get_buffer(), bufs field of >>> struct vb2_queue becomes like a private member of the structure. >>> >>> After each call to vb2_get_buffer() we need to be sure that we get >>> a valid pointer so check the return value of all of them. >> This needs to be extended: checking the returned pointer is a preparation >> for when buffers can be deleted. As it is right now, checking for a >> NULL pointer isn't needed. >> >> I wonder if it isn't better to drop those checks and instead apply them >> at the tail end of this series when the actual work on deleting buffers >> starts (before patch 49, I think). > > I think that checking vb2_get_buffer() return value while removing direct > call to queue buffers array doesn't hurt here. > It is also needed to do that before "media: videobuf2: Add helper to get queue number of buffers" patch. If we convert the drivers first, then there is (I think) no need to split this patch in two parts, since then this patch is part of a much shorter series and it is sufficient to just mention in the commit log that the pointer checks prepare for deleting buffers. Regards, Hans > > Regards, > Benjamin > >> >> Regards, >> >>     Hans >> >>> Signed-off-by: Benjamin Gaignard >>> --- >>>   .../media/common/videobuf2/videobuf2-core.c   | 151 +++++++++++++----- >>>   .../media/common/videobuf2/videobuf2-v4l2.c   |  51 ++++-- >>>   2 files changed, 146 insertions(+), 56 deletions(-) >>