Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp843876pxk; Thu, 24 Sep 2020 22:11:03 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxWSPsS/PsLtQP4T1B4k6W0rw7XD34rt5dI1a7V6l1Uh6tTs89tBm8sH8wIadRWPW3XoR+Q X-Received: by 2002:aa7:cd05:: with SMTP id b5mr2174194edw.283.1601010663619; Thu, 24 Sep 2020 22:11:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601010663; cv=none; d=google.com; s=arc-20160816; b=Jke68sdcDdh3Y/fmdUI+ivDlyxL93PKJs+P9t008GniW3c92pUoyuZ65UFrQ9RU0bj 2DqI7uETnBAUoQIshjIgiTAzjH5fbh5U/sM1aaByivEk57/avxR+oTk+YCQeTuHdh8us LXgNGIk0wszYxvRJAySbIOhU17XaPtDkdTy1GK+k+U3DyYCj5HN4c3PZrwpDDaoHtGZi jkCt9ahuO1SZgxv6e/jaZfxfU5VnJlqM9eugkDi+Fhn0EMK7q15rulFCsRxqs6Ss9yRR MUsJiieM1Py1Wut+ECkbdwVL3zIVTfW6mBGMRD4c6VjClc0ZF9WJKBWNR1JKxQGoQHs1 +mSA== 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=Lq7jj1jEymgd8G4nyQA4jtkDJNMv6Jix8ulHY5QmLFg=; b=GH9rs67/sCITkVb77n1yJudwatQCYt4YS4abA2rOh5Lc3kHBm3xlUAlWuglIS7YMti tOttPmvzrhqNdJvBklt+CudeTlPWZFRyC5Lg9fO3oQUbUSUgAjVILjWYYf09NJlD2plO 8h3SVacrU007vJeO51zS7pC9YTKPp6SKTgn58tZOrr+GWe1yMHR5RhqeFMPMc7maFvns bj7rut7StgKzaiwelAo3yhVSxsDk87NpOqKiZnh/L4T9bXSl5A2v/TLf+7yOJGwMPcvf Rp40Chk94WtV4HPb+9LHZwbsimM7khTp9dkfTIy7LOQ2nlYyPC48GK4rVDHKXWE/UfVF EjWw== 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 p21si1083949edq.151.2020.09.24.22.10.38; Thu, 24 Sep 2020 22:11:03 -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 S1727044AbgIYFIU (ORCPT + 99 others); Fri, 25 Sep 2020 01:08:20 -0400 Received: from mail1.windriver.com ([147.11.146.13]:48677 "EHLO mail1.windriver.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726908AbgIYFIU (ORCPT ); Fri, 25 Sep 2020 01:08:20 -0400 Received: from ALA-HCB.corp.ad.wrs.com (ala-hcb.corp.ad.wrs.com [147.11.189.41]) by mail1.windriver.com (8.15.2/8.15.2) with ESMTPS id 08P5877L011172 (version=TLSv1 cipher=DHE-RSA-AES256-SHA bits=256 verify=FAIL); Thu, 24 Sep 2020 22:08:07 -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:08:01 -0700 From: To: , CC: , Subject: [PATCH v2] kernel/kthread.c: kthread_worker: add work status check in timer_fn Date: Fri, 25 Sep 2020 13:07:59 +0800 Message-ID: <20200925050759.20805-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 "work->canceling" check current work status. Signed-off-by: Zqiang --- v1->v2: Change description information. 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