lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <9cb9a6dc-1bc6-ce32-0948-8f87014aae87@collabora.com>
Date:   Sun, 25 Dec 2022 01:14:53 +0100
From:   Robert Mader <robert.mader@...labora.com>
To:     Ezequiel Garcia <ezequiel@...guardiasur.com.ar>,
        Benjamin Gaignard <benjamin.gaignard@...labora.com>
Cc:     Nicolas Dufresne <nicolas.dufresne@...labora.com>,
        Philipp Zabel <p.zabel@...gutronix.de>,
        Mauro Carvalho Chehab <mchehab@...nel.org>,
        Hans Verkuil <hverkuil-cisco@...all.nl>, kernel@...labora.com,
        linux-media@...r.kernel.org, linux-rockchip@...ts.infradead.org,
        linux-kernel@...r.kernel.org
Subject: Re: [PATCH v2] hantro: Fix JPEG encoder ENUM_FRMSIZE on RK3399

On 24.12.22 18:03, Ezequiel Garcia wrote:
> On Sat, Dec 24, 2022 at 09:03:59AM +0100, Benjamin Gaignard wrote:
>> Le 23/12/2022 à 19:16, Nicolas Dufresne a écrit :
>>> Since 79c987de8b354, enumerating framesize on format set with "MODE_NONE"
>>> (any raw formats) is reporting an invalid frmsize.
>>>
>>>     Size: Stepwise 0x0 - 0x0 with step 0/0
>>>
>>> Before this change, the driver would return EINVAL, which is also invalid but
>>> worked in GStreamer. The original intent was not to implement it, hence the
>>> -ENOTTY return in this change. While drivers should implement ENUM_FRMSIZE for
>>> all formats and queues, this change is limited in scope to fix the regression.
>>>
>>> This fixes taking picture in Gnome Cheese software, or any software using
>>> GSteamer to encode JPEG with hardware acceleration.
>>>
>>> Fixes: 79c987de8b354 ("media: hantro: Use post processor scaling capacities")
>>> Reported-by: Robert Mader <robert.mader@...labora.com>
>>> Signed-off-by: Nicolas Dufresne <nicolas.dufresne@...labora.com>
>> Reviewed-by: Benjamin Gaignard <benjamin.gaignard@...labora.com>
>>
> Reviewed-by: Ezequiel Garcia <ezequiel@...guardiasur.com.ar>
>
> Thanks,
> Ezequiel

Tested-by: Robert Mader <robert.mader@...labora.com>

Thanks a lot for this Christmas present, confirmed that it fixes the 
affected apps / use-cases for me :)

>
>>> ---
>>>    drivers/media/platform/verisilicon/hantro_v4l2.c | 7 +++++--
>>>    1 file changed, 5 insertions(+), 2 deletions(-)
>>>
>>> diff --git a/drivers/media/platform/verisilicon/hantro_v4l2.c b/drivers/media/platform/verisilicon/hantro_v4l2.c
>>> index 2c7a805289e7b..30e650edaea8a 100644
>>> --- a/drivers/media/platform/verisilicon/hantro_v4l2.c
>>> +++ b/drivers/media/platform/verisilicon/hantro_v4l2.c
>>> @@ -161,8 +161,11 @@ static int vidioc_enum_framesizes(struct file *file, void *priv,
>>>    	}
>>>    	/* For non-coded formats check if postprocessing scaling is possible */
>>> -	if (fmt->codec_mode == HANTRO_MODE_NONE && hantro_needs_postproc(ctx, fmt)) {
>>> -		return hanto_postproc_enum_framesizes(ctx, fsize);
>>> +	if (fmt->codec_mode == HANTRO_MODE_NONE) {
>>> +		if (hantro_needs_postproc(ctx, fmt))
>>> +			return hanto_postproc_enum_framesizes(ctx, fsize);
>>> +		else
>>> +			return -ENOTTY;
>>>    	} else if (fsize->index != 0) {
>>>    		vpu_debug(0, "invalid frame size index (expected 0, got %d)\n",
>>>    			  fsize->index);

-- 
Robert Mader
Consultant Software Developer

Collabora Ltd.
Platinum Building, St John's Innovation Park, Cambridge CB4 0DS, UK
Registered in England & Wales, no. 5513718

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ