Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2510070pxj; Mon, 10 May 2021 04:52:02 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzUr1Ol5YiEaLrpCfnW46SoPC2Qwil264FkGHA5nU0yJktyxhUQVR8Gde1nM/YRCB4Lc8yh X-Received: by 2002:a17:906:c827:: with SMTP id dd7mr25429090ejb.225.1620647521950; Mon, 10 May 2021 04:52:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620647521; cv=none; d=google.com; s=arc-20160816; b=dH7xZDuorIfYEcDHWAkHvkWI0hdcC0bdSNWlIEwIWYnxfZvGbgIWVgu5iwRYayAPaJ oIZre20Fy9fWV5QZau1HAKr09Jxh6eBwk4oiiSEiazqbHGHIvBBNpSSGzc6+iWEvpUZu aACgXvMDQ1I5VGLhMqzo6H5f+cX/y5cZ5oB38weemb/RCiVb7jKgpDB/nehL59wh9EqM 1x08KHmZzg2C5qjW10uketf8d22C0a/LGvl1xcbm47EEdqF6Dl2MjBxnAWakPseIsw0i KvA/196bw+PMjudg5O46b+1k5V3mXPTHOo4egaF1D298Ouq91/if/2byriX8eJFAR5QV ReaQ== 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=VI/9c1aHq1Q0RlFaxzIlly22xChcN5P6J+zouprAdRk=; b=vAcIZgQORrxawXx3NFSo7mlMe7eoqEiLl4n9G6aHqkyQm1X26GygdiAxru97iiBqSb uBn4loArOm8jyJERb4+dQQtOyuukzagSOhD6W5A6iWBXSu0cTuce8NT1fWny3JVzhpQU nMT1hVtZLy690ZzUIm3fhzXnglSTR9LQb8xEYAIUV+z1IJz7bywyl4qjeUTv4gmvktR+ 2bO3bdjOgNWu34glRheDV4IFG9ZrqoZYnegux52HWog/YvgVIw8x7Nl3EtSboJcrmz/Z 4rE+IbiVIBTLU4KumOHnXoGs1USWxspqnLvDvZ6SDaJXk1v4lBRB4hrhxyMXs2l0Lwqx ql7w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=tViLla1Z; 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 t6si12854828ejj.37.2021.05.10.04.51.37; Mon, 10 May 2021 04:52: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=tViLla1Z; 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 S242269AbhEJLlg (ORCPT + 99 others); Mon, 10 May 2021 07:41:36 -0400 Received: from mail.kernel.org ([198.145.29.99]:53006 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231593AbhEJK5i (ORCPT ); Mon, 10 May 2021 06:57:38 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 95D3261A13; Mon, 10 May 2021 10:51:45 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620643906; bh=kW+Kz7+iyT/blgzYJhQ6JJtZ8Tz4bngwHmfpwDRDbB8=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=tViLla1Zwcsc4pnz4zyZS7jaMYVmIZkPSD6x7DTxXRL5Ucx8UiqRvYOII0piUr8sY Do19PmbfmEismYohF2G5CJTHuikPs8i744Z/TM1nMWNtpMRgfv9tZmwBBw+2qLWrxq hmJA3tuqXaeqWm7ymnGKCTlNYFieZCmMz/hjTMbk= 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.11 207/342] media: i2c: adv7842: fix possible use-after-free in adv7842_remove() Date: Mon, 10 May 2021 12:19:57 +0200 Message-Id: <20210510102016.925981135@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210510102010.096403571@linuxfoundation.org> References: <20210510102010.096403571@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 4a15275b6a18597079f18241c87511406575179a ] 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/adv7842.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/media/i2c/adv7842.c b/drivers/media/i2c/adv7842.c index 0855f648416d..f7d2b6cd3008 100644 --- a/drivers/media/i2c/adv7842.c +++ b/drivers/media/i2c/adv7842.c @@ -3586,7 +3586,7 @@ static int adv7842_remove(struct i2c_client *client) struct adv7842_state *state = to_state(sd); adv7842_irq_enable(sd, false); - cancel_delayed_work(&state->delayed_work_enable_hotplug); + cancel_delayed_work_sync(&state->delayed_work_enable_hotplug); v4l2_device_unregister_subdev(sd); media_entity_cleanup(&sd->entity); adv7842_unregister_clients(sd); -- 2.30.2