Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp3889086pxv; Mon, 19 Jul 2021 11:11:45 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyoFrEnF2rmuR2dYWplKJO+sRxVEVdWILWX3M+N5N/46hIu+BJSH3CX/2KEUUBHrUb7fRjh X-Received: by 2002:a17:907:d28:: with SMTP id gn40mr26374734ejc.415.1626718304710; Mon, 19 Jul 2021 11:11:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626718304; cv=none; d=google.com; s=arc-20160816; b=JUWbzdHzYRe31KjPvE2DQhQaT5AjBdV9HBcQT0iGFYLvKIBnFMV0Gchgjf84K9Xh8o AGnksMCljIJFsScSsVSIsWHt6rQk657CtFVVrOJZYOMDunWzNfNj/MWWPE0OuMjkcUw9 3Kcs9oJN9e+Ke2li3dstzv+gagNdptUTumoTkK3FrZdKS/OkOFgKdqxcm81Q820jYAAD Szwbw3RgHe46wLpD+5flIR62R/8l+VofKBkvvRScUFdxUWkDp+/M/8+ZxNub7mLdaNzG ZRL5ztf75OrjdTxSxekmvrlxaBq29HyIa09jVzVhdHAKSr8iKa9/CqdsrMvXa0j/CdgK SBxA== 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=9CdBjDNwH5Ds39G7eOWqVAnAa/1Ij/Npfy72wB1NnYA=; b=hclEtTboT2fc/TiSUwUbWXX6afRICE/oXuTvxuR1lAEz0YUgb10hMMi4Od9ObkSBsf OYsl01+ajmHqcb0/eownDerEQ30xDQRnAjwtXWLRjbilDyNHucx05fDeL6ZMWg+3xW9C fa1yWxoU0LIRQlKfThoVpdMyPiD7rlxpAovvZ66oqSz6iL+FOrUb3ignfs8M/k8/4yCH H2eujS3AfIwhMJH5gbdgb8bd8UJfYAGjtkCuP3B3os70KwQwBc1vhDCpRQEAPpEnRm0w XOIr/uUSGnF1xTBkY8ISz7PvSeCusCpENapqB9YvvbGmGh04TOns4NXcUEqf5C7kU5iG zg8w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=kqNkh8O4; 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 u13si12524098ejz.673.2021.07.19.11.11.20; Mon, 19 Jul 2021 11:11:44 -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=kqNkh8O4; 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 S1355782AbhGSRYF (ORCPT + 99 others); Mon, 19 Jul 2021 13:24:05 -0400 Received: from mail.kernel.org ([198.145.29.99]:43682 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1349159AbhGSPoy (ORCPT ); Mon, 19 Jul 2021 11:44:54 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 8D71061450; Mon, 19 Jul 2021 16:23:45 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626711826; bh=0rOQmzH2/RHjeIWMPO1I5FaTDOuQ4tbgwtr7wXAqSH0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=kqNkh8O4oMzz7gVvbdjWN336094c8dmoFPFs3WmgfsGxd8O3W4FIQdzZoNtRGDYdn KnzD2fVxJ3/cZDXxZ4z60f9YE/CG4S7t2/j7UZZQ68xH3CTCn6HaNX0Hv1kLoVQEYs 53k1qby7wBD77wA6JnfQfJlpVEWf2gnw+Vixp5PE= 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.12 145/292] watchdog: Fix possible use-after-free in wdt_startup() Date: Mon, 19 Jul 2021 16:53:27 +0200 Message-Id: <20210719144947.251827507@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210719144942.514164272@linuxfoundation.org> References: <20210719144942.514164272@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 c08a6b31e4917034f0ed0cb457c3bb209576f542 ] 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/1620716495-108352-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/sbc60xxwdt.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/watchdog/sbc60xxwdt.c b/drivers/watchdog/sbc60xxwdt.c index a947a63fb44a..7b974802dfc7 100644 --- a/drivers/watchdog/sbc60xxwdt.c +++ b/drivers/watchdog/sbc60xxwdt.c @@ -146,7 +146,7 @@ static void wdt_startup(void) static void wdt_turnoff(void) { /* Stop the timer */ - del_timer(&timer); + del_timer_sync(&timer); inb_p(wdt_stop); pr_info("Watchdog timer is now disabled...\n"); } -- 2.30.2