Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp1188941imj; Thu, 14 Feb 2019 02:40:40 -0800 (PST) X-Google-Smtp-Source: AHgI3IYHBf2tZeu/vW9w7w9jSumZAF2MkqKOgiJLuVbsXuygJJSGnkQTYmxdVCDfSxQ7ux54pG5H X-Received: by 2002:aa7:85cc:: with SMTP id z12mr3347346pfn.196.1550140840504; Thu, 14 Feb 2019 02:40:40 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550140840; cv=none; d=google.com; s=arc-20160816; b=yG3NZOQQ5xQtMZZevX8wcH+sEcS+Jx9qiYsDOyn0z3XFF072GoXHqLQLplvWVBWgnN BUUD8lMg8peLHJz8IS6rTwV5q4Dr9ZkUdnSsUNAOOUvJK4sJzMyMVotYVPUGtXe98Avc y1Y5qqlNOOY7sp/IU2x9/jCqIxgLTwXO2tyi8Sbxku+Y4A435LEH35XTC53j1WBP7TRh tdPE/dEsyM0T6SI1oDaxP4L9GyBmQ3aeUA6h7IIwGk4hkSaoL/KAxAmIFmD7wW8wS4sq FjBW4xu1eG3dtCIlTfk9EB1uu7iCuNgPMIpC/8MAyNsLx1gY2O+ULxybat1RUJ+ajGJI tSCA== 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:cc:to:subject :message-id:date:from:in-reply-to:references:mime-version :dkim-signature; bh=kemjfnjIuml2bUANw718ZFbm67WbkNNq5J0JFs4U+2k=; b=nsv8rG4x6I7qwT3vFc8UEcOprABqIEWJtX+DtZFXmUGip3FfXTFbKK1D5FSh6oj/YB ulDDteGLYi9KtvHF9HlgApI6dLuvyFdzktWPrNdsoLrZW53sfIHAYqMXZ/BxaMETOmuS 22gCMRtwcltXdPiJ6ZnaynZ9MmC4eKAQ+/iWk6WerEX80NXLEVDKeaKsV4jK/r5gtNXv xnk8LGNKQ1vPFm4xrUHCt9282Jh/Jw4eBrSunmEnJaJyJjH7RpbkL0G0MFZPrJl9+LoD l2Fd3mnQt7U7nXFo6ZHoCQ6M7V7ksfRngsTnmPi0WyJ9NYpmEtTmyEoY2HaZq77WMVDR lVFw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b="BxS/Ghfb"; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d142si2053984pfd.93.2019.02.14.02.40.24; Thu, 14 Feb 2019 02:40:40 -0800 (PST) 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; dkim=pass header.i=@chromium.org header.s=google header.b="BxS/Ghfb"; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2390492AbfBNCn6 (ORCPT + 99 others); Wed, 13 Feb 2019 21:43:58 -0500 Received: from mail-ot1-f65.google.com ([209.85.210.65]:39460 "EHLO mail-ot1-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389120AbfBNCn5 (ORCPT ); Wed, 13 Feb 2019 21:43:57 -0500 Received: by mail-ot1-f65.google.com with SMTP id n8so8056242otl.6 for ; Wed, 13 Feb 2019 18:43:56 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc:content-transfer-encoding; bh=kemjfnjIuml2bUANw718ZFbm67WbkNNq5J0JFs4U+2k=; b=BxS/GhfbamAR7sBBj4/SwSDTJ6ihb2iDqPzv59ibWrwivsj7sUZ1J49eCyFLBxd4vY aOyqpbEyrMP4ujObjJQ0PQkmUu9Vf2kHe2KP+sfn0lf/9qMfNFjwH+2Lr0z6FmLkcWyn AMS3l+miB7S8QzM4tiawyAd24x0wKpi+rWxNQ= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc:content-transfer-encoding; bh=kemjfnjIuml2bUANw718ZFbm67WbkNNq5J0JFs4U+2k=; b=GP4uTf6kiOQ487oLSqu/MJs6y/L9y6gzFtxNZbtfio9ATXdjPQUhBD2XjtNYCimr8A zMrpgW4vn/0eroEpfrmlJLe3oLXcJ6ZtCTDId4god3DvzD8hRWNm2KyO17DcsVZt/m8x KFsdIOcTOFKlbuRhiYkDvta8xKRjLioIMe253C29HGrPueiVf1zE7ivpcQqv1FpExYR1 o+HqWva1edDaaSUOaz7vf/F9xOcwbmVy+4KAzKPoMZ8xgf+aeKvIgnviNFSvtonDcto2 jRyD+je7fx3V1HzbREOIMzbuuKnFtOGpvDWQ0+SrzU8YaPW/nguC7jnaUYqcGUP3bDQ+ xK2A== X-Gm-Message-State: AHQUAuaW8k5gSf/W4fxUEwrmkrM93XbLm/0jFzyfjqD/FGdVrxAmmNr5 U4FZ2rV9VbKTmICnCD+awFY4ZdZ7LausLQ== X-Received: by 2002:aca:d06:: with SMTP id 6mr895299oin.166.1550112236011; Wed, 13 Feb 2019 18:43:56 -0800 (PST) Received: from mail-ot1-f49.google.com (mail-ot1-f49.google.com. [209.85.210.49]) by smtp.gmail.com with ESMTPSA id h1sm486417otm.0.2019.02.13.18.43.53 for (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 13 Feb 2019 18:43:53 -0800 (PST) Received: by mail-ot1-f49.google.com with SMTP id k98so8098021otk.3 for ; Wed, 13 Feb 2019 18:43:53 -0800 (PST) X-Received: by 2002:a9d:1d65:: with SMTP id m92mr873380otm.65.1550112233121; Wed, 13 Feb 2019 18:43:53 -0800 (PST) MIME-Version: 1.0 References: <20190117162008.25217-1-stanimir.varbanov@linaro.org> <20190117162008.25217-11-stanimir.varbanov@linaro.org> <28069a44-b188-6b89-2687-542fa762c00e@linaro.org> <57419418d377f32d0e6978f4e4171c0da7357cbb.camel@ndufresne.ca> <1548938556.4585.1.camel@pengutronix.de> <1f8485785a21c0b0e071a3a766ed2cbc727e47f6.camel@ndufresne.ca> In-Reply-To: From: Tomasz Figa Date: Thu, 14 Feb 2019 11:43:41 +0900 X-Gmail-Original-Message-ID: Message-ID: Subject: Re: [PATCH 10/10] venus: dec: make decoder compliant with stateful codec API To: Hans Verkuil , Nicolas Dufresne Cc: Philipp Zabel , Stanimir Varbanov , Linux Media Mailing List , Mauro Carvalho Chehab , Linux Kernel Mailing List , linux-arm-msm , Vikash Garodia , Alexandre Courbot , Malathi Gottam Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Feb 7, 2019 at 4:33 PM Tomasz Figa wrote: > > On Tue, Feb 5, 2019 at 7:35 PM Hans Verkuil wrote: > > > > On 2/5/19 10:31 AM, Tomasz Figa wrote: > > > On Tue, Feb 5, 2019 at 6:00 PM Hans Verkuil wrot= e: > > >> > > >> On 2/5/19 7:26 AM, Tomasz Figa wrote: > > >>> On Fri, Feb 1, 2019 at 12:18 AM Nicolas Dufresne wrote: > > >>>> > > >>>> Le jeudi 31 janvier 2019 =C3=A0 22:34 +0900, Tomasz Figa a =C3=A9c= rit : > > >>>>> On Thu, Jan 31, 2019 at 9:42 PM Philipp Zabel wrote: > > >>>>>> Hi Nicolas, > > >>>>>> > > >>>>>> On Wed, 2019-01-30 at 10:32 -0500, Nicolas Dufresne wrote: > > >>>>>>> Le mercredi 30 janvier 2019 =C3=A0 15:17 +0900, Tomasz Figa a = =C3=A9crit : > > >>>>>>>>> I don't remember saying that, maybe I meant to say there migh= t be a > > >>>>>>>>> workaround ? > > >>>>>>>>> > > >>>>>>>>> For the fact, here we queue the headers (or first frame): > > >>>>>>>>> > > >>>>>>>>> https://gitlab.freedesktop.org/gstreamer/gst-plugins-good/blo= b/master/sys/v4l2/gstv4l2videodec.c#L624 > > >>>>>>>>> > > >>>>>>>>> Then few line below this helper does G_FMT internally: > > >>>>>>>>> > > >>>>>>>>> https://gitlab.freedesktop.org/gstreamer/gst-plugins-good/blo= b/master/sys/v4l2/gstv4l2videodec.c#L634 > > >>>>>>>>> https://gitlab.freedesktop.org/gstreamer/gst-plugins-good/blo= b/master/sys/v4l2/gstv4l2object.c#L3907 > > >>>>>>>>> > > >>>>>>>>> And just plainly fails if G_FMT returns an error of any type.= This was > > >>>>>>>>> how Kamil designed it initially for MFC driver. There was no = other > > >>>>>>>>> alternative back then (no EAGAIN yet either). > > >>>>>>>> > > >>>>>>>> Hmm, was that ffmpeg then? > > >>>>>>>> > > >>>>>>>> So would it just set the OUTPUT width and height to 0? Does it= mean > > >>>>>>>> that gstreamer doesn't work with coda and mtk-vcodec, which do= n't have > > >>>>>>>> such wait in their g_fmt implementations? > > >>>>>>> > > >>>>>>> I don't know for MTK, I don't have the hardware and didn't inte= grate > > >>>>>>> their vendor pixel format. For the CODA, I know it works, if th= ere is > > >>>>>>> no wait in the G_FMT, then I suppose we are being really lucky = with the > > >>>>>>> timing (it would be that the drivers process the SPS/PPS synchr= onously, > > >>>>>>> and a simple lock in the G_FMT call is enough to wait). Adding = Philipp > > >>>>>>> in CC, he could explain how this works, I know they use GStream= er in > > >>>>>>> production, and he would have fixed GStreamer already if that w= as > > >>>>>>> causing important issue. > > >>>>>> > > >>>>>> CODA predates the width/height=3D0 rule on the coded/OUTPUT queu= e. > > >>>>>> It currently behaves more like a traditional mem2mem device. > > >>>>> > > >>>>> The rule in the latest spec is that if width/height is 0 then CAP= TURE > > >>>>> format is determined only after the stream is parsed. Otherwise i= t's > > >>>>> instantly deduced from the OUTPUT resolution. > > >>>>> > > >>>>>> When width/height is set via S_FMT(OUT) or output crop selection= , the > > >>>>>> driver will believe it and set the same (rounded up to macrobloc= k > > >>>>>> alignment) on the capture queue without ever having seen the SPS= . > > >>>>> > > >>>>> That's why I asked whether gstreamer sets width and height of OUT= PUT > > >>>>> to non-zero values. If so, there is no regression, as the specs m= imic > > >>>>> the coda behavior. > > >>>> > > >>>> I see, with Philipp's answer it explains why it works. Note that > > >>>> GStreamer sets the display size on the OUTPUT format (in fact we p= ass > > >>>> as much information as we have, because a) it's generic code and b= ) it > > >>>> will be needed someday when we enable pre-allocation (REQBUFS befo= re > > >>>> SPS/PPS is passed, to avoid the setup delay introduce by allocatio= n, > > >>>> mostly seen with CMA base decoder). In any case, the driver report= ed > > >>>> display size should always be ignored in GStreamer, the only > > >>>> information we look at is the G_SELECTION for the case the x/y or = the > > >>>> cropping rectangle is non-zero. > > >>>> > > >>>> Note this can only work if the capture queue is not affected by th= e > > >>>> coded size, or if the round-up made by the driver is bigger or equ= al to > > >>>> that coded size. I believe CODA falls into the first category, sin= ce > > >>>> the decoding happens in a separate set of buffers and are then de-= tiled > > >>>> into the capture buffers (if understood correctly). > > >>> > > >>> Sounds like it would work only if coded size is equal to the visibl= e > > >>> size (that GStreamer sets) rounded up to full macroblocks. Non-zero= x > > >>> or y in the crop could be problematic too. > > >>> > > >>> Hans, what's your view on this? Should we require G_FMT(CAPTURE) to > > >>> wait until a format becomes available or the OUTPUT queue runs out = of > > >> > > >> You mean CAPTURE queue? If not, then I don't understand that part. > > > > > > No, I exactly meant the OUTPUT queue. The behavior of s5p-mfc in case > > > of the format not being detected yet is to waits for any pending > > > bitstream buffers to be processed by the decoder before returning an > > > error. > > > > > > See https://elixir.bootlin.com/linux/v5.0-rc5/source/drivers/media/pl= atform/s5p-mfc/s5p_mfc_dec.c#L329 > > > > It blocks?! That shouldn't happen. Totally against the spec. > > > > Yeah and that's what this patch tries to implement in venus as well > and is seemingly required for compatibility with gstreamer... > Hans, Nicolas, any thoughts? > > > . > > > > > >> > > >>> buffers? > > >> > > >> First see my comment here regarding G_FMT returning an error: > > >> > > >> https://www.spinics.net/lists/linux-media/msg146505.html > > >> > > >> In my view that is a bad idea. > > > > > > I don't like it either, but it seemed to be the most consistent and > > > compatible behavior, but I'm not sure anymore. > > > > > >> > > >> What G_FMT should return between the time a resolution change was > > >> detected and the CAPTURE queue being drained (i.e. the old or the ne= w > > >> resolution?) is something I am not sure about. > > > > > > Note that we're talking here about the initial stream information > > > detection, when the driver doesn't have any information needed to > > > determine the CAPTURE format yet. > > > > IMHO the driver should just start off with some default format, it > > really doesn't matter what that is. > > > > I guess that's fine indeed. > > > This initial situation is really just a Seek operation: you have a form= at, > > you seek to a new position and when you find the resolution of the > > first frame in the bitstream it triggers a SOURCE_CHANGE event. Actuall= y, > > to be really consistent with the Seek: you only need to trigger this ev= ent > > if 1) the new resolution is different from the current format, or 2) th= e > > capture queue is empty. 2) will never happen during a normal Seek, so > > that's a little bit special to this initial situation. > > Having the error returned allowed the applications to handle the > initial parsing without the event, though. It could have waited for > all the OUTPUT buffers to be dequeued and then call G_FMT to check if > that was enough data to obtain the format. Any thoughts on this one too? > > > > > The only open question is what should be done with any CAPTURE buffers > > that the application may have queued? Return one buffer with bytesused > > set to 0 and the LAST flag set? I think that would be consistent with > > the specification. I think this situation can happen during a regular > > seek operation as well. > > Yes, that would be reasonably consistent. > > > > > > > > >> > > >> On the one hand it is desirable to have the new resolution asap, on > > >> the other hand, returning the new resolution would mean that the > > >> returned format is inconsistent with the capture buffer sizes. > > >> > > >> I'm leaning towards either returning the new resolution. > > > > > > Is the "or ..." part of the sentence missing? > > > > Sorry, 'either' should be dropped from that sentence. > > > > Got it, thanks for clarification. > > > > > > > One of the major concerns was that we needed to completely stall the > > > pipeline in case of a resolution change, which made it hard to delive= r > > > a seamless transition to the users. An idea that comes to my mind > > > would be extending the source change event to actually include the > > > v4l2_format struct describing the new format. Then the CAPTURE queue > > > could keep the old format until it is drained, which should work fine > > > for existing applications, while the new ones could use the new event > > > data to determine if the buffers need to be reallocated. > > > > In my opinion G_FMT should return the new resolution after the > > SOURCE_CHANGE event was sent. So you know the new resolution at that > > point even though there may still be capture buffers pending with the > > old resolution. > > Agreed. That's how it's defined in current version. > > > > > What would be nice to have though is that the resolution could be part > > of v4l2_buffer. So as long as the new resolution would still fit inside > > the allocated buffers, you could just continue decoding without having > > to send a SOURCE_CHANGE event. > > Hmm, I'm not sure I follow. What we effectively care about when > deciding if we can continue decoding is whether the new sizeimage is > less or equal to the current buffer size. However we still need to > tell the application that the geometry changed. Otherwise it would > have to call G_FMT and G_SELECTION every frame and compare with > previous frame. And this one. Best regards, Tomasz