Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2549615pxj; Mon, 10 May 2021 05:42:59 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxlSh9jkITLF7uo6DHRj2W8cTUGhPEMC8Uwk5+tvSMctvUtsUBFXRqFyqymTV3rwQikZ52E X-Received: by 2002:a05:6402:5a:: with SMTP id f26mr29235975edu.306.1620650579363; Mon, 10 May 2021 05:42:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620650579; cv=none; d=google.com; s=arc-20160816; b=P5WTmycliuQYDo5I0ofNiJmHQbUvxf42HFZha3YltD9BHH/FHbAI4VYNNwHvQKav1B qPefiJTeLYvBdXJkqQr8a9zBwor5MYh4c4Desh4XtcDqa/TBstI0ZLDjGUs8ytHcYdOn NO4BNj/rh/vDYe88ZEn6Wx/qss8wuJXMfktCziazYHwnniafgliQAY94URRp6F4NKc1O ghmZSI/V87lv/ci0CYepWP7UaOX27Ghm9fp2JQSE4gYFQ+WUkuLcgQd1h0syxFfOlLv6 iZD9tcsC9YXwTjuMZcVcfGzZUBWtBBFJu51Td8SFeRMwyVshUgXDe0OSE+DA5PQvu4C+ 0t5A== 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=61BEFHa9fpK8VnJrazQQel/YF5BAR0WOip43nAEA8JA=; b=A0KwpcykUCqftPZ+R9Cmx9X69iNsKpg5a99wJOYzF221RzgXeVZnvsOjzohtwwgOck 4vO5QsiaO0AI2ScjqbuasgFG39jCY8dhrsmJPAOLZww87v4EMxuaQte7IHzSmFcmQZg/ YcFwGO85CiIQs1fmfwgRUDYqvJCaRbZORgvd+b5flqa82Fqk3P+5lzHFbNxbaOO0U+Vo JfWtEZEtUVkUacDNMsizEp3KtdqdBMsQHPA+ovmme/9io+RO4L/r0VZ5nlbpVYojj+7f UFOfmgubYyQE+izuCFsCwhg5Y0LiorM7X2unTtoMFY63JfT9wXP93jnbbTSIf4w1WCUY kK0A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=DLXMlkJn; 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 m2si12458407ejj.215.2021.05.10.05.42.36; Mon, 10 May 2021 05:42:59 -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=DLXMlkJn; 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 S1346617AbhEJMcD (ORCPT + 99 others); Mon, 10 May 2021 08:32:03 -0400 Received: from mail.kernel.org ([198.145.29.99]:45768 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237206AbhEJLLf (ORCPT ); Mon, 10 May 2021 07:11:35 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id D71146192C; Mon, 10 May 2021 11:08:10 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620644891; bh=jSFnpPCMOcIv5/ncZmQy4KGPp60iGDNp1gQ4t8bTZgo=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=DLXMlkJnb+d+qsDdCiDpXhkyoZoEph8Vcj0C3AOT+p6TCXQClmhgwUpo3Zeae53AH x3DuzxqWltHYP87CEYgXYGuQX6qr6hfa8ua5nOoLrQXI/VJlqr4NiAKENeWq4qRpIy 04+XKUY6oU/erM+q7AIzAytTtkTbM3DS2mTRe75k= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Hulk Robot , Yang Yingliang , Hans Verkuil , Mauro Carvalho Chehab , Sasha Levin Subject: [PATCH 5.12 232/384] media: i2c: tda1997: Fix possible use-after-free in tda1997x_remove() Date: Mon, 10 May 2021 12:20:21 +0200 Message-Id: <20210510102022.541210100@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210510102014.849075526@linuxfoundation.org> References: <20210510102014.849075526@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: Yang Yingliang [ Upstream commit 7f820ab5d4eebfe2d970d32a76ae496a6c286f0f ] This driver's remove path calls cancel_delayed_work(). However, that function does not wait until the work function finishes. This means that the callback function may still be running after the driver's remove function has finished, which would result in a use-after-free. Fix by calling cancel_delayed_work_sync(), which ensures that the work is properly cancelled, no longer running, and unable to re-schedule itself. Reported-by: Hulk Robot Signed-off-by: Yang Yingliang Signed-off-by: Hans Verkuil Signed-off-by: Mauro Carvalho Chehab Signed-off-by: Sasha Levin --- drivers/media/i2c/tda1997x.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/media/i2c/tda1997x.c b/drivers/media/i2c/tda1997x.c index a09bf0a39d05..89bb7e6dc7a4 100644 --- a/drivers/media/i2c/tda1997x.c +++ b/drivers/media/i2c/tda1997x.c @@ -2804,7 +2804,7 @@ static int tda1997x_remove(struct i2c_client *client) media_entity_cleanup(&sd->entity); v4l2_ctrl_handler_free(&state->hdl); regulator_bulk_disable(TDA1997X_NUM_SUPPLIES, state->supplies); - cancel_delayed_work(&state->delayed_work_enable_hpd); + cancel_delayed_work_sync(&state->delayed_work_enable_hpd); mutex_destroy(&state->page_lock); mutex_destroy(&state->lock); -- 2.30.2