Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp3789283pxv; Mon, 19 Jul 2021 08:47:27 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz4MPv8NOhvHOEzcWQunDnyXvyXkEHpN4iZ5vRWhP5/2KyRfb+FpN/fxb8f/5QhEX9LgVfG X-Received: by 2002:aa7:db11:: with SMTP id t17mr34818987eds.297.1626709647445; Mon, 19 Jul 2021 08:47:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626709647; cv=none; d=google.com; s=arc-20160816; b=b5IPjKmU/WvH1pjBX+l5JAJOLqFbVdZI7HDOJvij4ZRNo6R6AyXOwNd/0M2AHbn+9s /4DyvO9PUnT7XiAhqxw05jdD4oni8SXL6Y/mmMjImwj744UYduyans2h6AzEhnVwH3tE /8Bm2fecF9YUKku3RYp3tmCEUIwnAXMmVqcvIR8pbOol/YI1O2s0o1xKlGH684cSRvEU uXisZ2Kvpi/ky0Nt8nXHgs5gKrSTb4FcSCG7xG/rIVrwyRmZGJvplBnVijypo6PXsKuO /oUpofu+6hXbtROvfBJ8TSLsEe5YpN6JzZfMd43OmCe2cJtVLBfb1vKDZ8BuKdmvmldz UNmQ== 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=FdycLCNcIWHGQJBiYXEY8Q4qpCZOluljWZXe8dbxKPU=; b=Hc1hS4eZjiiDGeScGFad8lP6Up2SBax65X9wOxI3aaWe7LOa1OdQ37kp2lKDF1MVbI SwIvvcznZefrRqAPNIjO6CEdKjLrxg9hl/0kMG1+NLgzBHt2XE9pffsLlKNzrxawdwxs RlnCRsSaML3YxQRbfrc2d9I03aeb6qnx2A7R9gJmMjfaT117SlnKtIRWcw3w4h1Ks+YB Xiq391PaPV0Cameacg55AmgncbJTi3s7pSz8JGS0Qzw+Ul0t3sTa1Ihp10TrZDp1AdL4 DFUCjCSEwFe12eoc6j+G01zMpvz74SBqvSzXzyBg0vLxA49qG+n+7+sKMSY8nu8F13hv gRoA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=gccV+7R6; 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 u16si13630379ejo.602.2021.07.19.08.47.05; Mon, 19 Jul 2021 08:47:27 -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=gccV+7R6; 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 S245348AbhGSPCu (ORCPT + 99 others); Mon, 19 Jul 2021 11:02:50 -0400 Received: from mail.kernel.org ([198.145.29.99]:60798 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244082AbhGSOk0 (ORCPT ); Mon, 19 Jul 2021 10:40:26 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id CA9C261002; Mon, 19 Jul 2021 15:21:03 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626708064; bh=9iYzRJWA9VUMjadf/f1wc5risnPUGVQ9g4tnOeVEqoY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=gccV+7R6g35CiOh21sZDdE3Lh8iwo02Ix6llnHNNmCkXeOzfz7Rm/LKy4rrJ7MTNf 2yJurucfd3fyGcWTmX31Y5vSdfDx8VIfSSQn7ft1NXGBNBPVVBzh7g+uhGloiL9rre yAfp629yqZUBsIzT9CpCsm7t88dLPFMNti7W0/Lo= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Hulk Robot , Zou Wei , "David S. Miller" , Sasha Levin Subject: [PATCH 4.14 166/315] mISDN: fix possible use-after-free in HFC_cleanup() Date: Mon, 19 Jul 2021 16:50:55 +0200 Message-Id: <20210719144948.352823559@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210719144942.861561397@linuxfoundation.org> References: <20210719144942.861561397@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 009fc857c5f6fda81f2f7dd851b2d54193a8e733 ] 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 Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- drivers/isdn/hardware/mISDN/hfcpci.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/isdn/hardware/mISDN/hfcpci.c b/drivers/isdn/hardware/mISDN/hfcpci.c index d2e401a8090e..3e73cb5b8304 100644 --- a/drivers/isdn/hardware/mISDN/hfcpci.c +++ b/drivers/isdn/hardware/mISDN/hfcpci.c @@ -2349,7 +2349,7 @@ static void __exit HFC_cleanup(void) { if (timer_pending(&hfc_tl)) - del_timer(&hfc_tl); + del_timer_sync(&hfc_tl); pci_unregister_driver(&hfc_driver); } -- 2.30.2