Received: by 2002:ab2:2994:0:b0:1ef:ca3e:3cd5 with SMTP id n20csp114470lqb; Thu, 14 Mar 2024 06:58:59 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCWw5j3Hf/E8vs1hmcwl+fYNVrtW2+8i8M8CLTWNK0Iwtxm7/Zny3rao1Ttq27kVuW/iUwsUsUXOLdXhb8c0556u/7HPZ7YPLX54qEwY1w== X-Google-Smtp-Source: AGHT+IGskrFuHMXwx1Xj4cIMPikl+O0X9GQWL1YxiV9jAbAZAylRZzz4WP5f4KkMPcmrmTdaFm/G X-Received: by 2002:a17:903:2450:b0:1db:7052:2f45 with SMTP id l16-20020a170903245000b001db70522f45mr1950364pls.61.1710424739391; Thu, 14 Mar 2024 06:58:59 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1710424739; cv=pass; d=google.com; s=arc-20160816; b=B4ENtC1xlAVxtfKgGQLemwKnD2eKkRZW+yAS4WPHKh0HSqFbAczm0gJiEttOSeo2Tn qcylsl9Sbe8LDzzQJyZSlf8yA6gIU91ijv1U4eluM9SkTWBo6/P7GIKENS5KYiiuWfWp 4mCDZ+fU9b5ur7x++nk1pCMJqzxoacWdp+gZHgmzBf+eabLfJcr55vNy+owX3mc1aJvb /P3JEwGJVhpy8kmJaDWi1EWZHymEPgNxCINEB/fpfPkqndTVYyCv2g3xQb6UrCCboZot FfMtXeViiP/J6B6Puhj+wQM0eKRHKwPh0x8OL76kfhx04gQ2F12cjinYPtg8cc2Kntox xjLQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:date:message-id; bh=X0PyAfsPbk4cwQd0Pdhc/YdF4EpxlYBmWGnMBnl3VRE=; fh=Iw2X+XCBF3bEFkcduZ02pbj7SLQsAyRqiwYsV/hjARQ=; b=bY179LBHIGhshKxCxrb3rS9O7OuqU8v46R6QXrMDpX0q2NyPUjKjZ3SpygAufJuWKg mm+kFZ/TkHL5N5Va27GNW24EqSo9bCXesoKttglYQt0FJ/kkqaK2HygI306o9PqzI6+m LmxYErC1OSlRnTdYrMOi+jHFSndwlvMj2ez5z2UJMnmtmXTbfcsZoAB4BbMNRkZ5buiH gJ0MwQ3HE2NAVipanbk7YEofaOkKiEl0oIItc6dVZEEZWcNecTTmm7eK7zl1WZaUXHRe mmZyYpLWq2Q6vIf+QiapVMWoJtQlL50r8NgWgapKsCFQBx5ruVcIw90iD199bGNJQa63 GJ5A==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; arc=pass (i=1); spf=pass (google.com: domain of linux-kernel+bounces-103333-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45e3:2400::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-103333-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=xs4all.nl Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [2604:1380:45e3:2400::1]) by mx.google.com with ESMTPS id n15-20020a170902d2cf00b001dc3c3be4b4si1523913plc.645.2024.03.14.06.58.59 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 14 Mar 2024 06:58:59 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-103333-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45e3:2400::1 as permitted sender) client-ip=2604:1380:45e3:2400::1; Authentication-Results: mx.google.com; arc=pass (i=1); spf=pass (google.com: domain of linux-kernel+bounces-103333-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45e3:2400::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-103333-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=xs4all.nl Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id 1A9382887E9 for ; Thu, 14 Mar 2024 13:58:59 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 31CFF6F523; Thu, 14 Mar 2024 13:58:51 +0000 (UTC) Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 9C8FC6EB66; Thu, 14 Mar 2024 13:58:50 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710424730; cv=none; b=Ysed5QC0i3B/DIpdvP3dsu5+cs+YoFzafoW4r19n/MMU4GxhswRu7DfkRG0mO4ThmRV7BO+4fByp6CSY0AuZPAU+CedKf1u1/UZ9jvSNI/2AUJOWHgQ6Am27nR1mS2u9YNaMud2aZMNve0DkAKQ8iDPLo9rmmV2mwNvFOdOxfU0= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710424730; c=relaxed/simple; bh=mvD5ssDzIVgthtJ3QskynOisLec7WNLjvRxN6VzVWS4=; h=Message-ID:Date:MIME-Version:Subject:To:Cc:References:From: In-Reply-To:Content-Type; b=NUHv2Z9AV99X4bu9I3IP+xvfLmgZcOhUKoLSh6kctZG2I3A5MH8NAou8QG35TuHaoAEP3FOzl/5AfCDJVVExBnavX43cEhaOfIjedfA3T3BDer5TtYQwNxnIPxn2rWFFaJaW/mOsnKdhJNoHmjvErn43QTLfE97SvXdj+NzFV5M= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id 02C3FC433C7; Thu, 14 Mar 2024 13:58:47 +0000 (UTC) Message-ID: <83051ba5-4e49-4d65-8d92-7d159dc5e328@xs4all.nl> Date: Thu, 14 Mar 2024 14:58:47 +0100 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v20 8/9] media: v4l2: Add mem2mem helpers for REMOVE_BUFS ioctl Content-Language: en-US, nl To: Benjamin Gaignard , mchehab@kernel.org, tfiga@chromium.org, m.szyprowski@samsung.com, ezequiel@vanguardiasur.com.ar, p.zabel@pengutronix.de, nicolas@ndufresne.ca Cc: linux-media@vger.kernel.org, linux-kernel@vger.kernel.org, linux-rockchip@lists.infradead.org, kernel@collabora.com References: <20240221155435.100093-1-benjamin.gaignard@collabora.com> <20240221155435.100093-9-benjamin.gaignard@collabora.com> From: Hans Verkuil In-Reply-To: <20240221155435.100093-9-benjamin.gaignard@collabora.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit On 21/02/2024 4:54 pm, Benjamin Gaignard wrote: > Create v4l2-mem2mem helpers for VIDIOC_REMOVE_BUFS ioctl and > make test drivers use it. > > Signed-off-by: Benjamin Gaignard > --- > drivers/media/test-drivers/vicodec/vicodec-core.c | 1 + > drivers/media/test-drivers/vim2m.c | 1 + > drivers/media/test-drivers/vimc/vimc-capture.c | 1 + > drivers/media/test-drivers/visl/visl-video.c | 1 + > drivers/media/test-drivers/vivid/vivid-core.c | 1 + > drivers/media/v4l2-core/v4l2-mem2mem.c | 10 ++++++++++ > include/media/v4l2-mem2mem.h | 2 ++ > 7 files changed, 17 insertions(+) > > diff --git a/drivers/media/test-drivers/vicodec/vicodec-core.c b/drivers/media/test-drivers/vicodec/vicodec-core.c > index e13f5452b927..3e011fe62ae1 100644 > --- a/drivers/media/test-drivers/vicodec/vicodec-core.c > +++ b/drivers/media/test-drivers/vicodec/vicodec-core.c > @@ -1345,6 +1345,7 @@ static const struct v4l2_ioctl_ops vicodec_ioctl_ops = { > .vidioc_prepare_buf = v4l2_m2m_ioctl_prepare_buf, > .vidioc_create_bufs = v4l2_m2m_ioctl_create_bufs, > .vidioc_expbuf = v4l2_m2m_ioctl_expbuf, > + .vidioc_remove_bufs = v4l2_m2m_ioctl_remove_bufs, > > .vidioc_streamon = v4l2_m2m_ioctl_streamon, > .vidioc_streamoff = v4l2_m2m_ioctl_streamoff, > diff --git a/drivers/media/test-drivers/vim2m.c b/drivers/media/test-drivers/vim2m.c > index 3e3b424b4860..14aff4ad576b 100644 > --- a/drivers/media/test-drivers/vim2m.c > +++ b/drivers/media/test-drivers/vim2m.c > @@ -960,6 +960,7 @@ static const struct v4l2_ioctl_ops vim2m_ioctl_ops = { > .vidioc_dqbuf = v4l2_m2m_ioctl_dqbuf, > .vidioc_prepare_buf = v4l2_m2m_ioctl_prepare_buf, > .vidioc_create_bufs = v4l2_m2m_ioctl_create_bufs, > + .vidioc_remove_bufs = v4l2_m2m_ioctl_remove_bufs, > .vidioc_expbuf = v4l2_m2m_ioctl_expbuf, > > .vidioc_streamon = v4l2_m2m_ioctl_streamon, Perhaps leave this vim2m driver without remove_bufs support? The reason you didn't catch the uninitialized capabilities bug is that now all test drivers support this new ioctl. I think at least one should not support it to catch such issues. Regards, Hans > diff --git a/drivers/media/test-drivers/vimc/vimc-capture.c b/drivers/media/test-drivers/vimc/vimc-capture.c > index 97693561f1e4..ba7550b8ba7e 100644 > --- a/drivers/media/test-drivers/vimc/vimc-capture.c > +++ b/drivers/media/test-drivers/vimc/vimc-capture.c > @@ -221,6 +221,7 @@ static const struct v4l2_ioctl_ops vimc_capture_ioctl_ops = { > .vidioc_expbuf = vb2_ioctl_expbuf, > .vidioc_streamon = vb2_ioctl_streamon, > .vidioc_streamoff = vb2_ioctl_streamoff, > + .vidioc_remove_bufs = vb2_ioctl_remove_bufs, > }; > > static void vimc_capture_return_all_buffers(struct vimc_capture_device *vcapture, > diff --git a/drivers/media/test-drivers/visl/visl-video.c b/drivers/media/test-drivers/visl/visl-video.c > index b9a4b44bd0ed..f8d970319764 100644 > --- a/drivers/media/test-drivers/visl/visl-video.c > +++ b/drivers/media/test-drivers/visl/visl-video.c > @@ -539,6 +539,7 @@ const struct v4l2_ioctl_ops visl_ioctl_ops = { > .vidioc_prepare_buf = v4l2_m2m_ioctl_prepare_buf, > .vidioc_create_bufs = v4l2_m2m_ioctl_create_bufs, > .vidioc_expbuf = v4l2_m2m_ioctl_expbuf, > + .vidioc_remove_bufs = v4l2_m2m_ioctl_remove_bufs, > > .vidioc_streamon = v4l2_m2m_ioctl_streamon, > .vidioc_streamoff = v4l2_m2m_ioctl_streamoff, > diff --git a/drivers/media/test-drivers/vivid/vivid-core.c b/drivers/media/test-drivers/vivid/vivid-core.c > index 11b8520d9f57..771392f67dda 100644 > --- a/drivers/media/test-drivers/vivid/vivid-core.c > +++ b/drivers/media/test-drivers/vivid/vivid-core.c > @@ -769,6 +769,7 @@ static const struct v4l2_ioctl_ops vivid_ioctl_ops = { > .vidioc_expbuf = vb2_ioctl_expbuf, > .vidioc_streamon = vb2_ioctl_streamon, > .vidioc_streamoff = vb2_ioctl_streamoff, > + .vidioc_remove_bufs = vb2_ioctl_remove_bufs, > > .vidioc_enum_input = vivid_enum_input, > .vidioc_g_input = vivid_g_input, > diff --git a/drivers/media/v4l2-core/v4l2-mem2mem.c b/drivers/media/v4l2-core/v4l2-mem2mem.c > index 75517134a5e9..ba21c60f1ed3 100644 > --- a/drivers/media/v4l2-core/v4l2-mem2mem.c > +++ b/drivers/media/v4l2-core/v4l2-mem2mem.c > @@ -1386,6 +1386,16 @@ int v4l2_m2m_ioctl_create_bufs(struct file *file, void *priv, > } > EXPORT_SYMBOL_GPL(v4l2_m2m_ioctl_create_bufs); > > +int v4l2_m2m_ioctl_remove_bufs(struct file *file, void *priv, > + struct v4l2_remove_buffers *remove) > +{ > + struct v4l2_fh *fh = file->private_data; > + > + return vb2_core_remove_bufs(v4l2_m2m_get_vq(fh->m2m_ctx, remove->type), > + remove->index, remove->count); > +} > +EXPORT_SYMBOL_GPL(v4l2_m2m_ioctl_remove_bufs); > + > int v4l2_m2m_ioctl_querybuf(struct file *file, void *priv, > struct v4l2_buffer *buf) > { > diff --git a/include/media/v4l2-mem2mem.h b/include/media/v4l2-mem2mem.h > index 7f1af1f7f912..0af330cf91c3 100644 > --- a/include/media/v4l2-mem2mem.h > +++ b/include/media/v4l2-mem2mem.h > @@ -867,6 +867,8 @@ int v4l2_m2m_ioctl_reqbufs(struct file *file, void *priv, > struct v4l2_requestbuffers *rb); > int v4l2_m2m_ioctl_create_bufs(struct file *file, void *fh, > struct v4l2_create_buffers *create); > +int v4l2_m2m_ioctl_remove_bufs(struct file *file, void *priv, > + struct v4l2_remove_buffers *d); > int v4l2_m2m_ioctl_querybuf(struct file *file, void *fh, > struct v4l2_buffer *buf); > int v4l2_m2m_ioctl_expbuf(struct file *file, void *fh,