Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp4158004pxv; Mon, 19 Jul 2021 18:47:01 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyPurXNmLYep927A8Pl7a09ayS98jTzRAszDQQqGgKwyi/i7WfKy6MTyBC4cvpDjj58rt+s X-Received: by 2002:a92:b50d:: with SMTP id f13mr19122395ile.253.1626745621640; Mon, 19 Jul 2021 18:47:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626745621; cv=none; d=google.com; s=arc-20160816; b=0Msb/JT9gDqzGHt/h120uELVViqUb/aVsf2s3Ci1fuTodaiCZ+XFFPirDcrFIX7pAA Cfmdne6OOWO0JCuPY14xXYNHP3JVc0bcpKvE3MeRwqVoDYKvPzh5gWo+fBaAS5RY1Or0 vg/LmXNnvKHHZ1iQODRys8qQCZRCnC58hknZePQm0HTNrOWPlzlSYFe4M2LP1Oo6zOlq OPPqiVhQFCvgqw80mxSHHWCHwLHyGvGA6MS60ie1Tk3oyImDD9Rz0yznCJatJ+EWqFPe H/VOKOdqqGU0D14EpFuY+MfFw2orF0SMDhJHfvRNw8f+r4nliKZ3WcTq0P4j0O9Z2A2H vyww== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=wgLPTSst8b6eGhyLJSizDAiHTwzdOJULiA4DT1WRs0g=; b=yr1igney516sP+aVZseq0wG6gYMFfMUWXpw+Ox5nZd38py5p7BBdgWIvnbrOvmrcr7 dXvomorYrgdZd7GfDaUekvuLvICc2QUJPe19ai5mxlM/0Ii6uMYeHbbuZfe1SXeaOaZW WVo9G3d307tOm/o7ru1HKnK4s5UvS89lcz25pzVrxsjYVl+ZxkOA2xFMva1O6uv9Jx2x gRELV+W5bXhSQZdlNUnRVfUAtUsHK20CpRD0aGzctc9oCsQ44PP+NTRVaP/xzwDfGtFU +OIiEbg/9pC+vJDdbq9RQoX3oILVRqoVwUN2gbsmza6BqAtzEq5O/yXeED/xjPCI9wBH 9f+A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=Tcw0X8kf; 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=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id x99si11267042jah.122.2021.07.19.18.46.50; Mon, 19 Jul 2021 18:47:01 -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=@linuxfoundation.org header.s=korg header.b=Tcw0X8kf; 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=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1343570AbhGSPEG (ORCPT + 99 others); Mon, 19 Jul 2021 11:04:06 -0400 Received: from mail.kernel.org ([198.145.29.99]:54776 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244710AbhGSOhs (ORCPT ); Mon, 19 Jul 2021 10:37:48 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 88B7861205; Mon, 19 Jul 2021 15:17:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626707854; bh=cjIp7d6fAt+PZjTVIFvPwlCvRcdLEmBeXCKn5JVqF1E=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Tcw0X8kfEpTdWwQG4zc5PTJvDh22G5aUNtJXr/bEwpyTkSyekYRxv6TCQ942Izzii NRlhhVJnQsmztfC3O9BmJoQcm4ztsWslRyOAkmKAA/UQxjXTFVULkCbsQmHbayz5T2 SO638ABavT+vt5MeEfi38cF3Rn3U/6qk8TW8gLD4= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Lv Yunlong , Hans Verkuil , Mauro Carvalho Chehab , Sasha Levin Subject: [PATCH 4.14 084/315] media: exynos4-is: Fix a use after free in isp_video_release Date: Mon, 19 Jul 2021 16:49:33 +0200 Message-Id: <20210719144945.641656061@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210719144942.861561397@linuxfoundation.org> References: <20210719144942.861561397@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Lv Yunlong [ Upstream commit 01fe904c9afd26e79c1f73aa0ca2e3d785e5e319 ] 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 uses a variable 'is_singular_file' to avoid the uaf. v3: https://lore.kernel.org/patchwork/patch/1419058/ Fixes: 34947b8aebe3f ("[media] exynos4-is: Add the FIMC-IS ISP capture DMA driver") Signed-off-by: Lv Yunlong Signed-off-by: Hans Verkuil Signed-off-by: Mauro Carvalho Chehab Signed-off-by: Sasha Levin --- drivers/media/platform/exynos4-is/fimc-isp-video.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/drivers/media/platform/exynos4-is/fimc-isp-video.c b/drivers/media/platform/exynos4-is/fimc-isp-video.c index 39340abefd14..c9ef74ee476a 100644 --- a/drivers/media/platform/exynos4-is/fimc-isp-video.c +++ b/drivers/media/platform/exynos4-is/fimc-isp-video.c @@ -308,17 +308,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); -- 2.30.2