From: Sylwester Nawrocki <s.nawrocki@samsung.com>
To: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Cc: Mauro Carvalho Chehab <m.chehab@samsung.com>,
Marek Szyprowski <m.szyprowski@samsung.com>,
Pawel Osciak <pawel@osciak.com>,
linux-media@vger.kernel.org,
Kyungmin Park <kyungmin.park@samsung.com>,
Hans Verkuil <hverkuil@xs4all.nl>
Subject: Re: [PATCH v2] videobuf2-core: Verify planes lengths for output buffers
Date: Mon, 26 Aug 2013 17:03:11 +0200 [thread overview]
Message-ID: <521B6E2F.3050809@samsung.com> (raw)
In-Reply-To: <4180721.bTkb1na8CH@avalon>
On 08/26/2013 04:41 PM, Laurent Pinchart wrote:
> Hi Sylwester,
>
> On Monday 26 August 2013 11:32:01 Mauro Carvalho Chehab wrote:
>> Sylwester Nawrocki <s.nawrocki@samsung.com> escreveu:
>>> On 08/08/2013 02:35 PM, Laurent Pinchart wrote:
>>>> On Thursday 08 August 2013 14:14:30 Marek Szyprowski wrote:
>>>>> On 8/7/2013 12:44 PM, Laurent Pinchart wrote:
>>>>>> On Monday 12 November 2012 12:35:35 Laurent Pinchart wrote:
>>>>>>> On Friday 09 November 2012 15:33:22 Pawel Osciak wrote:
>>>>>>>> On Tue, Oct 16, 2012 at 8:37 AM, Laurent Pinchart wrote:
>>>>>>>>> For output buffers application provide to the kernel the number of
>>>>>>>>> bytes they stored in each plane of the buffer. Verify that the
>>>>>>>>> value is smaller than or equal to the plane length.
>>>>>>>>>
>>>>>>>>> Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
>>>>>>>>> Acked-by: Hans Verkuil <hans.verkuil@cisco.com>
>>>>>>>>> ---
>>>>>>>>
>>>>>>>> Acked-by: Pawel Osciak <pawel@osciak.com>
>>>>>>>
>>>>>>> You're listed, as well as Marek and Kyungmin, as videobuf2
>>>>>>> maintainers. When you ack a videobuf2 patch, should we assume that
>>>>>>> you will take it in your git tree ?
>>>>>>
>>>>>> Ping ? I'd like to get this patch in v3.12, should I send a pull
>>>>>> request ?
>>>>>
>>>>> Acked-by: Marek Szyprowski <m.szyprowski@samsung.com>
>>>>>
>>>>> Feel free to include it in your pull-request. I'm sorry for so huge
>>>>> delay in my response.
>>>>
>>>> No worries. I'll send a pull request to Mauro.
>>>>
>>>>>>>>> drivers/media/v4l2-core/videobuf2-core.c | 39
>>>>>>>>> +++++++++++++++++++
>>>>>>>>> 1 files changed, 39 insertions(+), 0 deletions(-)
>>>>>>>>>
>>>>>>>>> Changes compared to v1:
>>>>>>>>>
>>>>>>>>> - Sanity check the data_offset value for each plane.
>>>>>>>>>
>>>>>>>>> diff --git a/drivers/media/v4l2-core/videobuf2-core.c
>>>>>>>>> b/drivers/media/v4l2-core/videobuf2-core.c index 432df11..479337d
>>>>>>>>> 100644
>>>>>>>>> --- a/drivers/media/v4l2-core/videobuf2-core.c
>>>>>>>>> +++ b/drivers/media/v4l2-core/videobuf2-core.c
>>>>>>>>> @@ -296,6 +296,41 @@ static int __verify_planes_array(struct
>>>>>>>>> vb2_buffer
>>>>>>>>> *vb, const struct v4l2_buffer>
>>>>>>>>> }
>>>>>>>>>
>>>>>>>>> /**
>>>>>>>>> + * __verify_length() - Verify that the bytesused value for each
>>>>>>>>> plane
>>>>>>>>> fits in
>>>>>>>>> + * the plane length and that the data offset doesn't exceed the
>>>>>>>>> bytesused value.
>>>>>>>>> + */
>>>>>>>>> +static int __verify_length(struct vb2_buffer *vb, const struct
>>>>>>>>> v4l2_buffer *b)
>>>>>>>>> +{
>>>>>>>>> + unsigned int length;
>>>>>>>>> + unsigned int plane;
>>>>>>>>> +
>>>>>>>>> + if (!V4L2_TYPE_IS_OUTPUT(b->type))
>>>>>>>>> + return 0;
>>>>>>>>> +
>>>>>>>>> + if (V4L2_TYPE_IS_MULTIPLANAR(b->type)) {
>>>>>>>>> + for (plane = 0; plane < vb->num_planes; ++plane) {
>>>>>>>>> + length = (b->memory == V4L2_MEMORY_USERPTR)
>>>>>>>>> + ? b->m.planes[plane].length
>>>>>>>>> + : vb->v4l2_planes[plane].length;
>>>>>>>>> +
>>>>>>>>> + if (b->m.planes[plane].bytesused > length)
>>>>>>>>> + return -EINVAL;
>>>>>>>>> + if (b->m.planes[plane].data_offset >=
>>>>>>>>> + b->m.planes[plane].bytesused)
>>>>>>>>> + return -EINVAL;
>>>
>>> This patch causes regressions. After kernel upgrade applications that
>>> zero the planes array and don't set bytesused will stop working.
>>> We could say that these are buggy applications, but if it has been
>>> allowed for several kernel releases failing VIDIOC_QBUF on this check
>>> now is plainly a regression IMO. I guess Linus wouldn't be happy about
>>> a change like this.
>>>
>>> With this patch it is no longer possible to queue a buffer with bytesused
>>> set to 0. I think it shouldn't be disallowed to queue a buffer with no
>>> data to be used. So the check should likely be instead:
>>>
>>> if (b->m.planes[plane].bytesused > 0 &&
>>> b->m.planes[plane].data_offset >=
>>> b->m.planes[plane].bytesused)
>>> return -EINVAL;
>
> What about
>
> if (b->m.planes[plane].data_offset > 0 &&
> b->m.planes[plane].data_offset >=
> b->m.planes[plane].bytesused)
> return -EINVAL;
>
> If data_offset is non-zero we don't want to accept a zero bytesused value.
You're right, that looks better.
This will at least prevent failure of user space code like this one [1].
> We could also catch data_offset == 0 && bytesused == 0 with a WARN_ONCE to try
> and get userspace applications fixed (this should definitely have been caught
> from the very start).
But is it really a critical error condition ? IIRC s5p-mfc driver uses buffers
with bytesused = 0 to signal end of stream (I'm not judging whether it is
right or not at the moment). I'm no sure if such a configuration should be
disallowed right at the v4l2-core.
>>> Sorry for the late review of this.
>>
>> Makes sense. Could you please send such patch?
Sure, I'm preparing a patch. And...
[...]
>>>>>>>>> + ret = __verify_length(vb, b);
>>>>>>>>> + if (ret < 0)
additionally adding a debug print here, so it is easier to find out
why QBUF fails.
>>>>>>>>> + return ret;
>>>>>>>>> +
>>>>>>>>> switch (q->memory) {
>>>>>>>>> case V4L2_MEMORY_MMAP:
>>>>>>>>> ret = __qbuf_mmap(vb, b);
[1] http://cgit.freedesktop.org/gstreamer/gst-plugins-bad/tree/sys/mfc/fimc/fimc.c?id=0489f5277649826d1b38213c234fb0fe27206c2c#n543
--
Regards,
Sylwester
next prev parent reply other threads:[~2013-08-26 15:03 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-10-16 15:37 [PATCH v2] videobuf2-core: Verify planes lengths for output buffers Laurent Pinchart
2012-11-09 23:33 ` Pawel Osciak
2012-11-12 11:35 ` Laurent Pinchart
2013-08-07 10:44 ` Laurent Pinchart
2013-08-08 12:14 ` Marek Szyprowski
2013-08-08 12:35 ` Laurent Pinchart
2013-08-26 13:55 ` Sylwester Nawrocki
2013-08-26 14:32 ` Mauro Carvalho Chehab
2013-08-26 14:41 ` Laurent Pinchart
2013-08-26 15:03 ` Sylwester Nawrocki [this message]
2013-08-27 8:50 ` Laurent Pinchart
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=521B6E2F.3050809@samsung.com \
--to=s.nawrocki@samsung.com \
--cc=hverkuil@xs4all.nl \
--cc=kyungmin.park@samsung.com \
--cc=laurent.pinchart@ideasonboard.com \
--cc=linux-media@vger.kernel.org \
--cc=m.chehab@samsung.com \
--cc=m.szyprowski@samsung.com \
--cc=pawel@osciak.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox