Received: by 2002:a05:6a10:a841:0:0:0:0 with SMTP id d1csp4374156pxy; Tue, 27 Apr 2021 03:38:04 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxJYobG38zdP8sJY3EzNXLapUgaKx/JfDmSM73M/VE0ZdIZIyiLoFoI5uSehQruKG+UWf68 X-Received: by 2002:a17:90a:3f08:: with SMTP id l8mr4099962pjc.136.1619519884155; Tue, 27 Apr 2021 03:38:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1619519884; cv=none; d=google.com; s=arc-20160816; b=EzoxGXR2e42EH7e6CfqLNHcuXg+ybcRcMHtdS9+LPp//bXyJcDdjpiVVhr91wHrn2O wKAsyDwGfYJNzlcw+pG8k71h81f6TZPu/ol8H5GcFD7mnpz6vffEDBey6yYzQnIDDpHW 6qNAonpUipjD3GZJ3YieeebnnBStsBO8BTSLIMQI06k6SmTeUmcBV55R6RFwGfxISWD+ jQee4vhTKyO4RU2wflLJJCdDt25OAxSUgXfCU3k7gYbzUPsH4jXugiSBXFAsTtB74cpF g4CVNSSXIJeL6OIMuBJOWqvajwCLbIMsIa0gzErO9jdUtrjpjcTzMrYiVoxZ4FjReDaM VdlQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=ZelKz2I7px/DsM9936dSP42go4y+UUfhqVqjLNUu/iE=; b=aMIRYYctbSj1aVSNy9Hq36ej4Adpq72Xj6fjbOh3WAmv3Oqclbnfaj4QKN6/pvkk5k J5pw0SGjrA2ypxpYdMcP2VR+cr7vfuc0I4M1331q3arIM+c5ce9NjH0XVV4tMvpdctMf mYcEylRceAY/Cb389TWQQPDY3jS38c8CElg/2+I4jXL3L1DtyEFaK3bJ+TzhNuJYc3h2 8yKcFcyRa83yfg4Z/d9D1z/bgFA+jG1sIqFzUNv5FTGpMTSk+X3x2jsvX451ir69bCPo WHaEdGiFDtTkyHKI/15ExjJ1wcCgD/rbwfNPMk3w73i4QWQwyt0ZIT+WQQHjoDmCkNkr CoTg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=B69cMoui; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w5si3262535pfi.255.2021.04.27.03.37.51; Tue, 27 Apr 2021 03:38:04 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=B69cMoui; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237717AbhD0KiC (ORCPT + 99 others); Tue, 27 Apr 2021 06:38:02 -0400 Received: from mail.kernel.org ([198.145.29.99]:58752 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235370AbhD0Khl (ORCPT ); Tue, 27 Apr 2021 06:37:41 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 31ADF61164; Tue, 27 Apr 2021 10:36:51 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1619519812; bh=Pa3agcyz2NtuVM1ilvYU8h7J+lPkNnKb5CQvR3SYI/E=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=B69cMouiuHpSe3mPDuw5C/o/LAejhv6XpeioJvn43Fi9BaGuINCYDnxYJxIM7Z6vK spCHxaebUv6lD1tQ+6sfbV6jsPsjv4O8W20DWiTUJENniNfVUUke9Tf3UJCbHdne6c 0Nz04k1X8tjjjJRJunAR2+dGqWOrWJv+qLvHqrKeLkwzgaRtsa7yiQ5b2vDrUE3tDo SsAwPAEiqs8KFgEql5pf263/Jhe7I9eyOnqybU45DXaKCqKHvZ24al0CY6W6bnZ5tA fGHjqLt5jJs3NtaEa25WlwKMbukhgtOwMfxywljAWXj1xmm+Hk8wBv0+CyIERDeNN0 Ap9jC7LXEF/ig== Subject: Re: [PATCH v2] media:exynos4-is: Fix a use after free in isp_video_release To: Lv Yunlong Cc: linux-media@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-samsung-soc@vger.kernel.org, linux-kernel@vger.kernel.org, s.nawrocki@samsung.com, mchehab@kernel.org, krzk@kernel.org References: <20210427060255.3318-1-lyl2019@mail.ustc.edu.cn> From: Sylwester Nawrocki Message-ID: Date: Tue, 27 Apr 2021 12:36:48 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.7.1 MIME-Version: 1.0 In-Reply-To: <20210427060255.3318-1-lyl2019@mail.ustc.edu.cn> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 27.04.2021 08:02, Lv Yunlong wrote: > In isp_video_release, file->private_data is freed via > _vb2_fop_release()->v4l2_fh_release(). But the freed > file->private_data is still used in v4l2_fh_is_singular_file() > ->v4l2_fh_is_singular(file->private_data), which is a use > after free bug. > > My patch set file->private_data to NULL after _vb2_fop_release() > to avoid the use after free. > > Fixes: 34947b8aebe3f ("[media] exynos4-is: Add the FIMC-IS ISP capture DMA driver") > Signed-off-by: Lv Yunlong > --- > drivers/media/platform/exynos4-is/fimc-isp-video.c | 3 ++- > 1 file changed, 2 insertions(+), 1 deletion(-) > > diff --git a/drivers/media/platform/exynos4-is/fimc-isp-video.c b/drivers/media/platform/exynos4-is/fimc-isp-video.c > index 612b9872afc8..2e04589068b4 100644 > --- a/drivers/media/platform/exynos4-is/fimc-isp-video.c > +++ b/drivers/media/platform/exynos4-is/fimc-isp-video.c > @@ -315,7 +315,8 @@ static int isp_video_release(struct file *file) > } > > _vb2_fop_release(file, NULL); > - > + file->private_data = NULL; > if (v4l2_fh_is_singular_file(file)) { > fimc_pipeline_call(&ivc->ve, close); > Thank you for the patch. To ensure the pipeline stop call is done only when the last file handle is released we would need something as below. --------8<--------- diff --git a/drivers/media/platform/exynos4-is/fimc-isp-video.c b/drivers/media/platform/exynos4-is/fimc-isp-video.c index 612b9872afc8..3335fec509cb 100644 --- a/drivers/media/platform/exynos4-is/fimc-isp-video.c +++ b/drivers/media/platform/exynos4-is/fimc-isp-video.c @@ -306,17 +306,20 @@ static int isp_video_release(struct file *file) struct fimc_is_video *ivc = &isp->video_capture; struct media_entity *entity = &ivc->ve.vdev.entity; struct media_device *mdev = entity->graph_obj.mdev; + bool is_singular_file; mutex_lock(&isp->video_lock); - if (v4l2_fh_is_singular_file(file) && ivc->streaming) { + is_singular_file = v4l2_fh_is_singular_file(file); + + if (is_singular_file && ivc->streaming) { media_pipeline_stop(entity); ivc->streaming = 0; } _vb2_fop_release(file, NULL); - if (v4l2_fh_is_singular_file(file)) { + if (is_singular_file) { fimc_pipeline_call(&ivc->ve, close); mutex_lock(&mdev->graph_mutex); --------8<--------- Regards, Sylwester