Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp840298pxk; Thu, 24 Sep 2020 22:03:11 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwQAkrCI6JWXHGoyMkO4GaOIcEGnTfQkdjcJyKTLHp7qhGNxh0ZmY5fq5Jiq8IG4/1vLJ+y X-Received: by 2002:a17:906:a88a:: with SMTP id ha10mr1052716ejb.532.1601010191739; Thu, 24 Sep 2020 22:03:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601010191; cv=none; d=google.com; s=arc-20160816; b=Yf1ZVICfuDHglB2XmLsj//xFZ/4HgQEe10Cn0eisnlJstqYIP5gXrnDSSU1GMH40Y/ GlJmF6dQhQt7tXQgNm5D+r3ehTyxuBxBIlez7cXiCoDxYigjcZhvvIXly9JPgFcziEtO AO+wvbB3B1zOd6L0jmPFA4ZrcUQVB/stOxdddoq4nGM/iNj8GJF+Yle4KQ1ty/pPjsL4 E4Cq/RSQhYknooLikHwXrPQecHoNJkW2ZQQgtXlWakHkVscxHQEZsBi/CTz3Gd772B+p 0yNpjyo/2vYzNdMR+hhwjsiZ5lcWi91TTuKGvT/ArjdLOEUWOf0SqEmHFrK69u78x3wR LG6A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:subject:cc:to:from; bh=BZp78L1clC4iaWGukqwR1QMx/0jr8/G3sK5MJuvMHjA=; b=cx82vUqHnl097pYdbTVpqwW5qeWtQ3YZmehys3UbpShNo4bI3GYVr3xkQw7YyVTSWP 2XDeCHdd4Q8NMxC/15l+iSpmTHP/IbQSbEFpz1gwAr9bnGfj0c4sUEvqV2f9RpIpXC61 2/MKqzuADxAdVSiX7oPYM7wLax9BK6TljrZDCBUJozp/Oe2hSPV/nInYy9s3uwPWHmeT XiDO1oA+oqCWfwGQG9wpGGHCqtf6LmRkx4IRpo0PinTmqX42/PfoWvp9hqDsQ7CuZkrN kHo1zUkgIq/zSns2mOzXxq9CYN3DF4KPiUedGPTU2EDTo3cJlc4lhT3LPNqa0jnYBqvp i6sQ== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v13si1106032edi.95.2020.09.24.22.02.48; Thu, 24 Sep 2020 22:03:11 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727062AbgIYFBu (ORCPT + 99 others); Fri, 25 Sep 2020 01:01:50 -0400 Received: from mail.windriver.com ([147.11.1.11]:63933 "EHLO mail.windriver.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726925AbgIYFBu (ORCPT ); Fri, 25 Sep 2020 01:01:50 -0400 Received: from ALA-HCB.corp.ad.wrs.com (ala-hcb.corp.ad.wrs.com [147.11.189.41]) by mail.windriver.com (8.15.2/8.15.2) with ESMTPS id 08P51YiH010811 (version=TLSv1 cipher=DHE-RSA-AES256-SHA bits=256 verify=FAIL); Thu, 24 Sep 2020 22:01:35 -0700 (PDT) Received: from pek-qzhang2-d1.wrs.com (128.224.162.183) by ALA-HCB.corp.ad.wrs.com (147.11.189.41) with Microsoft SMTP Server id 14.3.487.0; Thu, 24 Sep 2020 22:01:15 -0700 From: To: , CC: , Subject: [PATCH] kernel/kthread.c: kthread_worker: add work status check in timer_fn Date: Fri, 25 Sep 2020 13:01:14 +0800 Message-ID: <20200925050114.20136-1-qiang.zhang@windriver.com> X-Mailer: git-send-email 2.17.1 MIME-Version: 1.0 Content-Type: text/plain Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Zqiang When queue delayed work to worker, at some point after that the timer_fn will be call, add work to worker's work_list, at this time, the work may be cancel, so add "queuing_blocked" check current work status. Signed-off-by: Zqiang --- kernel/kthread.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/kernel/kthread.c b/kernel/kthread.c index 3edaa380dc7b..85a2c9b32049 100644 --- a/kernel/kthread.c +++ b/kernel/kthread.c @@ -897,7 +897,8 @@ void kthread_delayed_work_timer_fn(struct timer_list *t) /* Move the work from worker->delayed_work_list. */ WARN_ON_ONCE(list_empty(&work->node)); list_del_init(&work->node); - kthread_insert_work(worker, work, &worker->work_list); + if (!work->canceling) + kthread_insert_work(worker, work, &worker->work_list); raw_spin_unlock_irqrestore(&worker->lock, flags); } -- 2.17.1