Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2463380pxj; Mon, 10 May 2021 03:41:58 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzKDxCDWXXoRMbMl8chiPaDjwNqujXCxLMsX0IzuLfEXk2E9dQxxB/yxQNvlNdQM5kBEgdC X-Received: by 2002:a17:906:8904:: with SMTP id fr4mr25332700ejc.146.1620643318506; Mon, 10 May 2021 03:41:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620643318; cv=none; d=google.com; s=arc-20160816; b=kOHk8OK+AmA4EZsCsV2gpQ9WEsZm9UwNlA+G170CaqyBH7fReCDS380CihOE83ueF6 u8bFFBaeXyNi/kbKci/es4dm/QJMJzuh+dH/BIjoMU+LG+1jFxTSomSSUoIXMjEiOlGh 3c/ITmqrWHNmZ0Ep22y4mqQa/yw8I7W66KTyPDnqFEKUHsHG0kVdEw6dZvRHW8jjN7sG piGNkCAycAmYcjuApvo7pt3UM/NX0IyEk5Abf0YQNV9gVu1fqUGzFTZj0D+kix1N440O yLIMp3FUZDjai8k5eNSmmhP4w9hTrz/TZDaJGkQTGu3rpwg2mOAYTb7cpXwHBtKzSRia vb2Q== 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=KU2Ao9LJ5wog2cUa2lcdgdEWbaq76fQ7FCycrSOz2PI=; b=v/w1CAhRH2Y/w7mnRxQ/Lj7TzWSNv52Cr9zFXCR1h1L4y2RHRjS775/PAoK7Z91U+B qf8gjsUKiF7a2YkDDE3lpMVucVkcqZCtU+bEYECLy0NU2An2txvL15VsobQOk+EBtZrJ jzjUsLPhb1HdvKcb6O2hfhRbHm9Tz9l7Iwf8/AA+tODsrqOEKTkSJdHzqYI7L0xxHs+h xfd8YIXNSy4zcD/LosAGpmsCfGw38PnPVwpMAfV3/OrHShphpbhvKO4C0pUCGyS8ZAZQ Q/BrG/wrEwVeiYKyG+nRbLLfm7oqGvzFO3azY4Ah/hb03qeOztlPS2VTahC62Q36BAOD pmRA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=wqcI9IUA; 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 c8si5588528edu.520.2021.05.10.03.41.35; Mon, 10 May 2021 03:41:58 -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=wqcI9IUA; 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 S231670AbhEJKiY (ORCPT + 99 others); Mon, 10 May 2021 06:38:24 -0400 Received: from mail.kernel.org ([198.145.29.99]:40904 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231845AbhEJKeC (ORCPT ); Mon, 10 May 2021 06:34:02 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 173B96146E; Mon, 10 May 2021 10:27:49 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620642470; bh=4HDkMF/rnkaFYhl4N7vbJp2w2Tc9rn69yJ6Y47iyDc4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=wqcI9IUA/uJgj8UObCg5zevrWYgn3lkfZImD7QhIXTKIloBI2N2pmM87JeB38goZH RlUSpwQm+sH3QTnMr0d1q8n/20ooqsheiTITm7U+3DplMFRfb4PnqwuvQtV2+ijSXF oPw7ejFgpjrwjUHI9bw8PXw1WcEln5WTdAD48vr4= 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.4 107/184] media: i2c: adv7511-v4l2: fix possible use-after-free in adv7511_remove() Date: Mon, 10 May 2021 12:20:01 +0200 Message-Id: <20210510101953.696375692@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210510101950.200777181@linuxfoundation.org> References: <20210510101950.200777181@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 2c9541720c66899adf6f3600984cf3ef151295ad ] 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/adv7511-v4l2.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/media/i2c/adv7511-v4l2.c b/drivers/media/i2c/adv7511-v4l2.c index 62763ec4cd07..809fa44ed988 100644 --- a/drivers/media/i2c/adv7511-v4l2.c +++ b/drivers/media/i2c/adv7511-v4l2.c @@ -1964,7 +1964,7 @@ static int adv7511_remove(struct i2c_client *client) adv7511_set_isr(sd, false); adv7511_init_setup(sd); - cancel_delayed_work(&state->edid_handler); + cancel_delayed_work_sync(&state->edid_handler); i2c_unregister_device(state->i2c_edid); i2c_unregister_device(state->i2c_cec); i2c_unregister_device(state->i2c_pktmem); -- 2.30.2