Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp2219759pxk; Sat, 26 Sep 2020 22:59:54 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxrXC6jT4ALlHXewI70fNLmnCaOFWpRS7BtiA8c1W5e612OKcDG5DCIIjWNlhb+xFbekYj1 X-Received: by 2002:a50:e807:: with SMTP id e7mr9726202edn.84.1601186394317; Sat, 26 Sep 2020 22:59:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601186394; cv=none; d=google.com; s=arc-20160816; b=aabDLnoOAVoUCEOYhI/pj4AjGwMBKxT3T7lLIjmSsUNMfLGeQmD9ZHlTRazETcYl6n 0+JIyCvIVvRVG06GDB5O8wtR73N2w1WpYO5gZPSHfy2XB0+HUBmeStQY5wVi8Jbh7qDW KrnmspVCIgiu59xg5d9zJ4fu6CBHfij0qOM2K5/baiffRbqDguv6Ae5yPYX2tGWpU6d2 65RU3bNRbRTxLqinjFZdOmyvockEmG/89XF9jc0ru5qtVAhovwxeK0a9ZCndZm+ylSBl 2lE3k4F/aarX6brxdCOVVwyQl/GzazgKIg8XmEAtlUfyFTSz2m2kfbZglx5L+vuIPsCT 8Tyg== 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=bTxZ0kEHan52qLyr+QAKy3G9dTz0WDZr6RZbmPhWDqg=; b=Zcz2aqSQ1SJyia7atI+BGpq3vT5iQzgRYLwbYsqAq3yYqsl0Cs8eZb4POwpzqayWC8 +0DzvyqJ1/CV7ByhsTBAssB7oQPFM/jzrZ9Tv/z7dE2HB1pc/SHVWpyMIUC960oNlunk AkliK3evVmFDjepivM4+tfkia3kyEhj+J35407AoNT5Rg5f4IVQLTrgJznmQGYLNabAT jBbEtqT7GDNmFUwHJdo23BZ9P9cGL6TckgVknCntiMeayb6dZVGIjKtpHZVBoN0GuyMl 3Vq29yjwMtq9LMSsdNT9SDzC+26EDdg6U7bNOXlM9eMWahzSLaPRsqqPAk72Fz+D/977 fNnw== 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 c24si5153125edw.144.2020.09.26.22.59.31; Sat, 26 Sep 2020 22:59:54 -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 S1730259AbgI0F5C (ORCPT + 99 others); Sun, 27 Sep 2020 01:57:02 -0400 Received: from mail5.windriver.com ([192.103.53.11]:57278 "EHLO mail5.wrs.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729125AbgI0F5C (ORCPT ); Sun, 27 Sep 2020 01:57:02 -0400 Received: from ALA-HCA.corp.ad.wrs.com (ala-hca.corp.ad.wrs.com [147.11.189.40]) by mail5.wrs.com (8.15.2/8.15.2) with ESMTPS id 08R5sfp4024676 (version=TLSv1 cipher=DHE-RSA-AES256-SHA bits=256 verify=FAIL); Sat, 26 Sep 2020 22:55:26 -0700 Received: from pek-qzhang2-d1.wrs.com (128.224.162.183) by ALA-HCA.corp.ad.wrs.com (147.11.189.40) with Microsoft SMTP Server id 14.3.487.0; Sat, 26 Sep 2020 22:54:51 -0700 From: To: , , CC: , Subject: [PATCH v3] kthread_worker: Prevent queuing delayed work from timer_fn when it is being canceled Date: Sun, 27 Sep 2020 13:54:49 +0800 Message-ID: <20200927055449.21389-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 There is a small race window when a delayed work is being canceled and the work still might be queued from the timer_fn: CPU0 CPU1 kthread_cancel_delayed_work_sync() __kthread_cancel_work_sync() __kthread_cancel_work() work->canceling++; kthread_delayed_work_timer_fn() kthread_insert_work(); BUG: kthread_insert_work() should not get called when work->canceling is set. Reviewed-by: Petr Mladek Signed-off-by: Zqiang --- v1->v2->v3: Change the description of the problem and add 'Reviewed-by' tags. 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