Received: by 2002:ab2:710b:0:b0:1ef:a325:1205 with SMTP id z11csp1737322lql; Wed, 13 Mar 2024 07:01:27 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCVE5MdkYru3vLhb5TQ55H4hBKuySvt7mPsrM2RnFT6qx8cCdaWAsL9lnzi3yprzh4KUeGckECenh7ckRIoaYrYMktQ2ytmZJNCXSnY4SQ== X-Google-Smtp-Source: AGHT+IFIM4CyEVjXYsYbxk2sx06cWKMj6usdAafZNk+c/ES2kP7ULi4jUwojoropv/C+UuCEtTqE X-Received: by 2002:a05:6a20:12c7:b0:1a3:2f8a:55fe with SMTP id v7-20020a056a2012c700b001a32f8a55femr3363209pzg.52.1710338487307; Wed, 13 Mar 2024 07:01:27 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1710338487; cv=pass; d=google.com; s=arc-20160816; b=IaeXLlJClRoHSQsGunvXhFl2+u7HC7zWUHDTQxdzNldUO1IjxC5ppVoCgu3AwORXDp 9LbwhQG+1E6KONsfSp4JUus8A8ZiOQAAW4ZglVKDWKIc5uwBnwUHHrD84YmAv2PZJ/xO rj3SONnU/quUd1RR5xFBBtxN3eQrsqXBQOYP9klWaiIA4HcDLCvR7+pywZ9zvWTN6DGd roObTQPhxHgQUj50OLGYMFu3yZicQy1y3gvLp3leRNj4Dr+XmXUTOxktR/iJtZteSXD3 oMs26JbQ9E3oY42i8eR0NZkVmZ4EltuN9Z2dCdI9PZKLS9SaiV79vroBAV/tKuDpSVza vFgQ== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=in-reply-to:content-disposition:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:message-id:subject:cc :to:from:date:dkim-signature; bh=NxRC8Fq9QERcJb2UzuZo004M89nErmy23IOOPk9M5fQ=; fh=dCN21vnQaayiWI31pahc3jK2Mho2SaZ3YMJ5GDvsmsM=; b=A8ASlu3mOPx0TbOlLremi6GSqWa+mu723sajU7ZdcCNjQV7yHaAKJJV4HCEjIsALz8 vrvNLO0kkwSWmonBebHGCfSvOJwEji0OVKVBEbGRjf1OT3UjS4SjnJZDQtNu3C/zwVjc 5wRSNhj8G1sz05ZJpS9oIkpBNzs7zQ8lauxBiVG7AMJvU3YnFtY1OdQXcKPqoN0v+ruK l9qBnLWSJH9uWEqrPhElXXo5Rqj7sijlZ2lAvhXkvpXuna2WoyQTAljS0VZlwhpDE93O Snq64eLnWZ9grkeQsV/OiWAb6yiQInuRW5Drr4tzeJ4GdOqkh4J2ZtBwS4EyKap63aLr Rbrw==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=j33gQHjb; arc=pass (i=1 spf=pass spfdomain=collabora.com dkim=pass dkdomain=collabora.com dmarc=pass fromdomain=collabora.com); spf=pass (google.com: domain of linux-kernel+bounces-101577-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-101577-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=collabora.com Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [139.178.88.99]) by mx.google.com with ESMTPS id v7-20020a63f847000000b005dc3614f98asi9233777pgj.542.2024.03.13.07.01.27 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 13 Mar 2024 07:01:27 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-101577-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) client-ip=139.178.88.99; Authentication-Results: mx.google.com; dkim=pass header.i=@collabora.com header.s=mail header.b=j33gQHjb; arc=pass (i=1 spf=pass spfdomain=collabora.com dkim=pass dkdomain=collabora.com dmarc=pass fromdomain=collabora.com); spf=pass (google.com: domain of linux-kernel+bounces-101577-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-101577-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=collabora.com 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 F369D286B4F for ; Wed, 13 Mar 2024 14:00:52 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 8A1F24501D; Wed, 13 Mar 2024 14:00:44 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=collabora.com header.i=@collabora.com header.b="j33gQHjb" Received: from madrid.collaboradmins.com (madrid.collaboradmins.com [46.235.227.194]) (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 1EA0E41C7F; Wed, 13 Mar 2024 14:00:41 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=46.235.227.194 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710338443; cv=none; b=PkcMdgOkZzu3NO1o1OBuf9JTDaCRGp0mHqaxvICQ4rWcrluSz0p8kjpL4AOHZN1BKKMYm+tf7CP/WxxKf9E1AYJ03uO3CY2p1dxS6yBWkUo0y6o8ogN+Rjf4dcrdyEbQdGCpwV8JJfp3bmZ3EBvTyTJ5hfUt6LK6fIGhWitPDUY= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1710338443; c=relaxed/simple; bh=sbE/oJOP+xX5Lc9uR9YZEG+4mUwEDJhSytN76LNWq08=; h=Date:From:To:Cc:Subject:Message-ID:References:MIME-Version: Content-Type:Content-Disposition:In-Reply-To; b=so8FmVHCHn3b42QdwR44dDfz5fLBovZ1D29q2O1HT+qP+MVfXUd+ypolyj2QpB9hLnyIfHelxCZCvveAJSzXpT1tsdK5vMQaWz8SLdi/Zq+WmoiwiHrmJxppwgOEMJyLvcpLJyyZmn8tjgIH8Oljv8yxJXJ4yeBUyt2Gn5X6ZqU= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=collabora.com; spf=pass smtp.mailfrom=collabora.com; dkim=pass (2048-bit key) header.d=collabora.com header.i=@collabora.com header.b=j33gQHjb; arc=none smtp.client-ip=46.235.227.194 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=collabora.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=collabora.com DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=collabora.com; s=mail; t=1710338440; bh=sbE/oJOP+xX5Lc9uR9YZEG+4mUwEDJhSytN76LNWq08=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=j33gQHjbQ2kOimxuku7kTz/iiCCqlQEC3yHUb+UJe92MzppLMEq+gkRySJvkDSof0 lVKWvU5jtadwhR3aEABQ2G5pswNXmV6HelhaehNPoM2S9qKqllE0YZMSSp25wowUrB 1NPJAq96Pp23tO21I4Wj1Hr2r31g0N4xOZIyqHbADxRacfPfzMAki3SR5o7a1MZKd6 99mrqoOEjFWU7S8yQVIMBUu3ISDCMNFWz0OgmPxlAlRVVWAWDR5lP4zJnbN2Vato6r mVpdU1xBQHCbtaPwUqgJ87I6cm9Auz9AETBf/o1Elr/zLImxXL/t/S3XpIG2FeRwXM YYlP3pg+IsMng== Received: from localhost (cola.collaboradmins.com [195.201.22.229]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange ECDHE (prime256v1) server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) (Authenticated sender: sebastianfricke) by madrid.collaboradmins.com (Postfix) with ESMTPSA id E925937820D4; Wed, 13 Mar 2024 14:00:38 +0000 (UTC) Date: Wed, 13 Mar 2024 15:00:28 +0100 From: Sebastian Fricke To: Nicolas Dufresne Cc: Tiffany Lin , Andrew-CT Chen , Yunfei Dong , Mauro Carvalho Chehab , Matthias Brugger , AngeloGioacchino Del Regno , Hans Verkuil , kernel@collabora.com, linux-media@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org Subject: Re: [PATCH] media: mediatek: vcodec: Fix oops when HEVC init fails Message-ID: <20240313140028.zk47awvadwfrutu6@basti-XPS-13-9310> References: <20240226211954.400891-1-nicolas.dufresne@collabora.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8; format=flowed Content-Disposition: inline In-Reply-To: <20240226211954.400891-1-nicolas.dufresne@collabora.com> Hey Nicolas, On 26.02.2024 16:19, Nicolas Dufresne wrote: >In stateless HEVC case, the instance pointer was saved in the >context regardless if the initialization worked. As the pointer >is freed in failure, this resulted in use after free in the >deinit function. just to fix some grammatic erros in the commit log, my suggestion: ``` The stateless HEVC decoder saves the instance pointer in the context regardless if the initialization worked or not. This caused a use after free, when the pointer is freed in case of a failure in the deinit function. Only store the instance pointer when the initialization was successful, to solve this issue. ``` Greetings, Sebastian > > Hardware name: Acer Tomato (rev3 - 4) board (DT) > pstate: 80400009 (Nzcv daif +PAN -UAO -TCO -DIT -SSBS BTYPE=--) > pc : vcodec_vpu_send_msg+0x4c/0x190 [mtk_vcodec_dec] > lr : vcodec_send_ap_ipi+0x78/0x170 [mtk_vcodec_dec] > sp : ffff80008750bc20 > x29: ffff80008750bc20 x28: ffff1299f6d70000 x27: 0000000000000000 > x26: 0000000000000000 x25: 0000000000000000 x24: 0000000000000000 > x23: ffff80008750bc98 x22: 000000000000a003 x21: ffffd45c4cfae000 > x20: 0000000000000010 x19: ffff1299fd668310 x18: 000000000000001a > x17: 000000040044ffff x16: ffffd45cb15dc648 x15: 0000000000000000 > x14: ffff1299c08da1c0 x13: ffffd45cb1f87a10 x12: ffffd45cb2f5fe80 > x11: 0000000000000001 x10: 0000000000001b30 x9 : ffffd45c4d12b488 > x8 : 1fffe25339380d81 x7 : 0000000000000001 x6 : ffff1299c9c06c00 > x5 : 0000000000000132 x4 : 0000000000000000 x3 : 0000000000000000 > x2 : 0000000000000010 x1 : ffff80008750bc98 x0 : 0000000000000000 > Call trace: > vcodec_vpu_send_msg+0x4c/0x190 [mtk_vcodec_dec] > vcodec_send_ap_ipi+0x78/0x170 [mtk_vcodec_dec] > vpu_dec_deinit+0x1c/0x30 [mtk_vcodec_dec] > vdec_hevc_slice_deinit+0x30/0x98 [mtk_vcodec_dec] > vdec_if_deinit+0x38/0x68 [mtk_vcodec_dec] > mtk_vcodec_dec_release+0x20/0x40 [mtk_vcodec_dec] > fops_vcodec_release+0x64/0x118 [mtk_vcodec_dec] > v4l2_release+0x7c/0x100 > __fput+0x80/0x2d8 > __fput_sync+0x58/0x70 > __arm64_sys_close+0x40/0x90 > invoke_syscall+0x50/0x128 > el0_svc_common.constprop.0+0x48/0xf0 > do_el0_svc+0x24/0x38 > el0_svc+0x38/0xd8 > el0t_64_sync_handler+0xc0/0xc8 > el0t_64_sync+0x1a8/0x1b0 > Code: d503201f f9401660 b900127f b900227f (f9400400) > >Signed-off-by: Nicolas Dufresne >Fixes: 2674486aac7d ("media: mediatek: vcodec: support stateless hevc decoder") >--- > .../mediatek/vcodec/decoder/vdec/vdec_hevc_req_multi_if.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > >diff --git a/drivers/media/platform/mediatek/vcodec/decoder/vdec/vdec_hevc_req_multi_if.c b/drivers/media/platform/mediatek/vcodec/decoder/vdec/vdec_hevc_req_multi_if.c >index 06ed47df693bf..21836dd6ef85a 100644 >--- a/drivers/media/platform/mediatek/vcodec/decoder/vdec/vdec_hevc_req_multi_if.c >+++ b/drivers/media/platform/mediatek/vcodec/decoder/vdec/vdec_hevc_req_multi_if.c >@@ -869,7 +869,6 @@ static int vdec_hevc_slice_init(struct mtk_vcodec_dec_ctx *ctx) > inst->vpu.codec_type = ctx->current_codec; > inst->vpu.capture_type = ctx->capture_fourcc; > >- ctx->drv_handle = inst; > err = vpu_dec_init(&inst->vpu); > if (err) { > mtk_vdec_err(ctx, "vdec_hevc init err=%d", err); >@@ -898,6 +897,7 @@ static int vdec_hevc_slice_init(struct mtk_vcodec_dec_ctx *ctx) > mtk_vdec_debug(ctx, "lat hevc instance >> %p, codec_type = 0x%x", > inst, inst->vpu.codec_type); > >+ ctx->drv_handle = inst; > return 0; > error_free_inst: > kfree(inst); >-- >2.43.2 > >_______________________________________________ >Kernel mailing list -- kernel@mailman.collabora.com >To unsubscribe send an email to kernel-leave@mailman.collabora.com >This list is managed by https://mailman.collabora.com