Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp3430042imm; Mon, 8 Oct 2018 04:02:32 -0700 (PDT) X-Google-Smtp-Source: ACcGV62TAgpW3rSNEVGdARZr8j44JV0YysfL3gW6dJSBsHBsvh9ZTGCFmS/xpuaeMciARCjKkHrv X-Received: by 2002:a62:5887:: with SMTP id m129-v6mr19736496pfb.254.1538996552521; Mon, 08 Oct 2018 04:02:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1538996552; cv=none; d=google.com; s=arc-20160816; b=E0+Taaax4fng46cRBNoV90rT+5PjKC6uvXjBmzctwUXDP82UcDerJ6Tyu2uPVXh4/T HixZ6Aw2+rlsF/gFMYYvrq8lwPRnHGuYgqVRFv1eHMoQWF++OnFHWqDyep4mDL67NJT7 dggNjK1zZ7g5oAfARElO99ROZJxsdo7Y4GF0FibuRyDzCaOdSY+N1Wgk1VTalDGROr51 YHPx+kiL2mUjqU81zgW3IYJOzWtxxBzFVn8+RNc/aIdWS9BIm2M60AhGyw8Zp6bB11cX TpWDFgWt7KoV9rIpWj7CMDQKI2Gm+KCD2eI8JKxImy/RZVFZinbBZ3X00q0WKzcry0Pc 8lhQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=jiGy86WoHIdVgCzXpPFMgUP4nrwMPCSa7N22cwFDCFg=; b=seTuDVCE19mihJdJawow6G1eB1UDuHvtFMqGmyzvpjR9xzuDYG6iTOdmaUdHrQFmTy 9VoXPWui7CLOTUNT+X0zaoX2lePNWiYhQBh9WcEuKniBK2DGZYGbazX7KY9lBTUOwNpb AYXZT4CLHJvSfqe49LeiZUpQIYk1aBjiENX3PtSY/tHy6Kp5/ICwpwCKjhTgQL9/t49n C/TL0LSWm8nfGBdhXfApzYwcFRvTaaCCgU75koED+CDsFSKeTQgNNPC5Zr9BwmO8fhK0 PCPzWgRRZIOJR6nuP8iag5Q8y7UHRfUX9GSXQFy2LfoOhz3Rx4XRdapffEiicyBelxor g4lg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d30-v6si17553949pla.200.2018.10.08.04.02.16; Mon, 08 Oct 2018 04:02:32 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727388AbeJHSNO (ORCPT + 99 others); Mon, 8 Oct 2018 14:13:14 -0400 Received: from lb2-smtp-cloud9.xs4all.net ([194.109.24.26]:54624 "EHLO lb2-smtp-cloud9.xs4all.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726656AbeJHSNO (ORCPT ); Mon, 8 Oct 2018 14:13:14 -0400 Received: from [192.168.2.10] ([212.251.195.8]) by smtp-cloud9.xs4all.net with ESMTPA id 9TIUgLs6rSskC9TIYgg3A5; Mon, 08 Oct 2018 13:02:02 +0200 Subject: Re: [RFC PATCH v2] media: docs-rst: Document m2m stateless video decoder interface To: Alexandre Courbot , Tomasz Figa , Paul Kocialkowski , Mauro Carvalho Chehab , Pawel Osciak , linux-media@vger.kernel.org Cc: linux-kernel@vger.kernel.org References: <20181004081119.102575-1-acourbot@chromium.org> From: Hans Verkuil Message-ID: <676a5e92-86c2-cf5a-9409-ef490ad8e828@xs4all.nl> Date: Mon, 8 Oct 2018 13:01:58 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.2.1 MIME-Version: 1.0 In-Reply-To: <20181004081119.102575-1-acourbot@chromium.org> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit X-CMAE-Envelope: MS4wfCtMBV/mRYme5OOozQQi3+mtEiTBjFu5IOszXa20nOLxsEFAWFv4RrN4AicW5/spIXholRaE0vIU+NaTR3377Vb2K2KlDY/+KxpqsfEouyb7X2O4vRUk ZGIKzaEQb2IOno4z8avHGK3GhWjuQ42uTZzg4LDttvlQP+hionVQk00ejdSAnP/LVKbCOF3feW/0xFcMxmFV7CtcF9qr6mXbVOOfw8ZfkrxJo7NHl5Xu01Z2 KQD64DurMzuJ86gH67N8+fuqHHERXEWGA86s+Y4S9AYF1TI5ZLxAx0O3BjrWMRFjISg0Tv0ZkZSTGUtL8OuFgnRPWTlaQyyZxgYVA2zSNcPteDR8KCvlaKsT W/ZUkgvB6eriveyflxzBx+xb2+RFiu42vBg63NrIz/dT/jovpLU= Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 10/04/2018 10:11 AM, Alexandre Courbot wrote: > This patch documents the protocol that user-space should follow when > communicating with stateless video decoders. It is based on the > following references: > > * The current protocol used by Chromium (converted from config store to > request API) > > * The submitted Cedrus VPU driver > > As such, some things may not be entirely consistent with the current > state of drivers, so it would be great if all stakeholders could point > out these inconsistencies. :) > > This patch is supposed to be applied on top of the Request API V18 as > well as the memory-to-memory video decoder interface series by Tomasz > Figa. > > Changes since V1: > > * Applied fixes received as feedback, > * Moved controls descriptions to the extended controls file, > * Document reference frame management and referencing (need Hans' feedback on > that). > > Signed-off-by: Alexandre Courbot > --- > .../media/uapi/v4l/dev-stateless-decoder.rst | 348 ++++++++++++++++++ > Documentation/media/uapi/v4l/devices.rst | 1 + > .../media/uapi/v4l/extended-controls.rst | 25 ++ > .../media/uapi/v4l/pixfmt-compressed.rst | 54 ++- > 4 files changed, 424 insertions(+), 4 deletions(-) > create mode 100644 Documentation/media/uapi/v4l/dev-stateless-decoder.rst > > diff --git a/Documentation/media/uapi/v4l/dev-stateless-decoder.rst b/Documentation/media/uapi/v4l/dev-stateless-decoder.rst > +Buffer management during decoding > +================================= > +Contrary to stateful decoder drivers, a stateless decoder driver does not > +perform any kind of buffer management. In particular, it guarantees that > +``CAPTURE`` buffers will be dequeued in the same order as they are queued. This > +allows user-space to know in advance which ``CAPTURE`` buffer will contain a > +given frame, and thus to use that buffer ID as the key to indicate a reference > +frame. > + > +This also means that user-space is fully responsible for not queuing a given > +``CAPTURE`` buffer for as long as it is used as a reference frame. Failure to do > +so will overwrite the reference frame's data while it is still in use, and > +result in visual corruption of future frames. > + > +Note that this applies to all types of buffers, and not only to > +``V4L2_MEMORY_MMAP`` ones, as drivers supporting ``V4L2_MEMORY_DMABUF`` will > +typically maintain a map of buffer IDs to DMABUF handles for reference frame > +management. Queueing a buffer will result in the map entry to be overwritten > +with the new DMABUF handle submitted in the :c:func:`VIDIOC_QBUF` ioctl. The more I think about this, the more I believe that relying on capture buffer indices is wrong. It's easy enough if there is a straightforward 1-1 relationship, but what if you have H264 slices as Nicolas mentioned and it becomes a N-1 relationship? Yes, you can still do this in userspace, but it becomes a lot more complicated. And what if in the future instead of having one capture buffer per decoded frame there will be multiple capture buffers per decoded frame, each with a single slice (for example)? I would feel much happier if we used a 'cookie' to refer to buffers. The next problem would be where to put it. I dislike abusing the timestamp field for this. Part of the reason is that there will be changes there to fix the year 2038 issue, and I am not entirely sure what that will do to how this field is handled since there may be conversions from a pre-2038 timeval to a 2038-ready timeval. So a union with the timestamp field and a cookie field (+ BUF_FLAG_COOKIE) would work best IMHO. Regards, Hans