Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp3850875pxv; Mon, 19 Jul 2021 10:14:04 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxVfSiD5bwgDzO6+egVnrOmYsgdDT6vEDWniyOPHY/ni0yqxf1UoJk4COPmd3Low2Ogy1q9 X-Received: by 2002:a92:d083:: with SMTP id h3mr18031944ilh.157.1626714844233; Mon, 19 Jul 2021 10:14:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626714844; cv=none; d=google.com; s=arc-20160816; b=emlBP9IdpxKm8V0BOyX7+vC1+Wa12p8Z7E51hgq61ugIhrOBX5Uje3wLkFY3BTnn11 bxraJgD1Spc3UU8F6VTsBZg8Cwl8oQz1KG4S0tCVaoac6moFjbV4j15ukv3rW7Id0nG/ jEDKHKpd8H50w8VCvi2/VpqISlL0vKI2f4ghC6ZaN3GM0gePmd+fXtnZ+4Tij+XH26ir z/VzOvlxJWhdUhmG04aI1rEdqqi++v1MDSgjAmAuOWVRLKpVI7fAZc2B6CfvH18lDdTx NiNDnLNRPbI0OAtZRQmMpEEbJnKtgHs5tHEpCRwi5HpI2F8sN9YGy69101DUEYD7Ndkc hPIQ== 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=xNi/bcufOG1YyHEV3qAh8ag3tV5eh8bPp+Hu/fBKov39BrYbgJqFDHCkHTrjoMYhsI nWiu2QuyrbJsLAIk/gxGfbA2/bdYs2NhWXu3gJcTYBlQzw6nKQl2SdCYCeooeYYerrat eoie1EJm1dQ2NGJ2bTVVfAn5t5ORMoJN53M0LqR9lJ4fS6vHLt5X/tzNswPiKw9C+aww jA+w5JNHbL6Z6YNlBahi5SIuqqZN5gcZfUcVAV7DQr7FhA+b2K8e15rM835kkUWg57p4 ecrYmFhwZzAoD7xm3r1Teyts/SXJJUpP4lIPjbZ55VlYi5tPn2Nynqbkox20HQUecbyX s2Pw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=r+7plskB; 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 t18si8460160ilf.96.2021.07.19.10.13.52; Mon, 19 Jul 2021 10:14:04 -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=r+7plskB; 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 S1351020AbhGSQb1 (ORCPT + 99 others); Mon, 19 Jul 2021 12:31:27 -0400 Received: from mail.kernel.org ([198.145.29.99]:56736 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1347411AbhGSPQM (ORCPT ); Mon, 19 Jul 2021 11:16:12 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 78E876121F; Mon, 19 Jul 2021 15:56:51 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626710212; bh=0rOQmzH2/RHjeIWMPO1I5FaTDOuQ4tbgwtr7wXAqSH0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=r+7plskBncslcXmBAjo9MtVbNYd1Tye/5uoaabR8f1QInfypVE6/mHZW17zigoZJw 0XxJ/MF/ZbYoRJamWU+vGqdHgCpQe063lXWCXoLRWH+jk/Hbxu6aZzzt1Q44A0eTGJ EdDLhK3CLTYFBQnb5G/2ofjbxYx+HP1x7B5iOtVI= 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.10 123/243] watchdog: Fix possible use-after-free in wdt_startup() Date: Mon, 19 Jul 2021 16:52:32 +0200 Message-Id: <20210719144944.879716723@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210719144940.904087935@linuxfoundation.org> References: <20210719144940.904087935@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