Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp3840136pxv; Mon, 19 Jul 2021 10:00:28 -0700 (PDT) X-Google-Smtp-Source: ABdhPJynO7akIOIf0MvfDNTb4pklBw12kY7s5I5yoWIW6DmT4G8jO8uN/fRUeKJjLqqjbqQYPlOy X-Received: by 2002:a05:6638:418f:: with SMTP id az15mr21075868jab.8.1626713949675; Mon, 19 Jul 2021 09:59:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626713949; cv=none; d=google.com; s=arc-20160816; b=D/ItF2EuwdhoVD+jNyPhQtkVSIqzUan4YzvetnpAg5YUYV7lOmQa9B7mjwfjFnFbtY eelKSE2ethJJ3yyjDz85O0bM8mskndDAvVvNOpmR852CVV+18HVguRr1NU1GIj1diqfg /6+HnzkB5KoR1j3wYqkOhhyvHpppF5BEqtv42E18zm6lY2mdhoYG2QmzubJGFn8SqvbT ki0oA3JlRl8hDfAsM7YAs7LkP75GBBmvzs7bIayMX6Tzmqb3gkDMnRDTGoNHPXBkwXxx bEwJFw1+8eCQhrZ48YDYOUMC1Y/WerHQ0bWoDre3hA+ot8hG+soG2R9mQAyzDMXlDZGg py6w== 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=MZuvP/Br5DcxqrINjwp0/XK9k91hZv/so0mZXvfW1EQ=; b=Eo84EofgzsivrJxx7/O8SJ1e4PSEz7IBcfZdN2LoABKBb4HvuJ8DJe0NKyHox3ijSo U8Xjd0Yj12eV5kT8+9osOxOwBtqyXDhguEO7AaBW6+pTsgU75inGDeJvEPhmedCB6xe8 Q4Q3UDAWNnRXmhWDkqAZVWHoiNKzYTS7si0YnVRbzGMYtf1zDLuhRCDpCdrKw88RBwwa atO8bWb3shsWO2bQUaTIZjjLD6MSVMm7FFOEXx3CiNaO2CTlg/9oJ7idp9pPNYBB4xay qdwJbOFQ7xv0vGkqFT2o/qiokrxU9KLJGSw43+6hM8ImO/Y4BNQynFo6hB+zrSkDVEnz WXOA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=JcSmSRMR; 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 m8si8566658jat.55.2021.07.19.09.58.57; Mon, 19 Jul 2021 09:59:09 -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=JcSmSRMR; 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 S1350678AbhGSQLs (ORCPT + 99 others); Mon, 19 Jul 2021 12:11:48 -0400 Received: from mail.kernel.org ([198.145.29.99]:40730 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1345491AbhGSPJY (ORCPT ); Mon, 19 Jul 2021 11:09:24 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id A5F0A61396; Mon, 19 Jul 2021 15:48:58 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626709739; bh=ms9YRNTIYNavmZmPXDww3mZ1tmy/t85F9z+8UsdPNmQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=JcSmSRMR7MkZuQ7aQ3vK8JQFXSyBu+ZQYYV2DiNofejfhuYGVB+sKtuaGbjDqm8BF HwSg4tz1k16x6GOtIuCTNgJ8W9EqibTFm/HSqXMyfE1H6ESsZNRt6MDEyieHJKz28N gthT7Mddlsn2SV6Y4Sk+ZGynm1C2aXpEGNld1sFE= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Hulk Robot , Zou Wei , Guenter Roeck , Wim Van Sebroeck , Sasha Levin Subject: [PATCH 5.4 078/149] watchdog: sc520_wdt: Fix possible use-after-free in wdt_turnoff() Date: Mon, 19 Jul 2021 16:53:06 +0200 Message-Id: <20210719144919.800166891@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210719144901.370365147@linuxfoundation.org> References: <20210719144901.370365147@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: Zou Wei [ Upstream commit 90b7c141132244e8e49a34a4c1e445cce33e07f4 ] This module's remove path calls del_timer(). However, that function does not wait until the timer handler finishes. This means that the timer handler may still be running after the driver's remove function has finished, which would result in a use-after-free. Fix by calling del_timer_sync(), which makes sure the timer handler has finished, and unable to re-schedule itself. Reported-by: Hulk Robot Signed-off-by: Zou Wei Reviewed-by: Guenter Roeck Link: https://lore.kernel.org/r/1620716691-108460-1-git-send-email-zou_wei@huawei.com Signed-off-by: Guenter Roeck Signed-off-by: Wim Van Sebroeck Signed-off-by: Sasha Levin --- drivers/watchdog/sc520_wdt.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/watchdog/sc520_wdt.c b/drivers/watchdog/sc520_wdt.c index a612128c5f80..57969564c7f9 100644 --- a/drivers/watchdog/sc520_wdt.c +++ b/drivers/watchdog/sc520_wdt.c @@ -186,7 +186,7 @@ static int wdt_startup(void) static int wdt_turnoff(void) { /* Stop the timer */ - del_timer(&timer); + del_timer_sync(&timer); /* Stop the watchdog */ wdt_config(0); -- 2.30.2