Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp4178523ybt; Sun, 5 Jul 2020 20:21:25 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx0Jt3ANbFu0NOsSTjzeNYBQ4NWN0InQIYve3K3vi+nazoSBY+/m8iNikHjKvwbFBPz5w/I X-Received: by 2002:a17:907:9484:: with SMTP id dm4mr43732226ejc.56.1594005685763; Sun, 05 Jul 2020 20:21:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1594005685; cv=none; d=google.com; s=arc-20160816; b=ikBNXxFVPG8ODcQ4o0t1L9FSu4g9jRd4XmGMefC6jf/czX1z/MVUV91WOaHasJdXKk bpjWGxySkfVz7m8e4+i/N4mVgkC8Lxt9+bQrlrEZXu4uza0z63pBqg4Dy/ULpWO9EU2w azfhjKpC391Q9h0cwGBZ8Pb5wwG3HnZQmVjYFh8fA2EXb5lqvt7xNasdmcgBIzbQNfzH JQcf5s4HhOoDeymkGvXbcscvSXqW4U4pAt/a4hmbNHkcmPXaBvrujVwZFnKfra2lWIfx FwJT7Ur4fNuk8fLWGpDGzSeB/5aZV+InqwW9+XrSHvptzF6hHl3AUw/+jq6kd+zKlvB5 TtJw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=oHF5TvYq0QaMvBBssI3KMcw0x/ZAmgaZUMOYxKh8gXY=; b=pHGqwCzN7zPaRK0JtiAMOdkuDaWVJq6nOr5S/q5dxRMKRQe9mcs+dzg5rpMnQ/+eCH qxA8cV9LTB3/zpbks80DUWnAP9/tDFVPSIKmXFZ/lsDlqJdEcc2NnNr8B5SVoDCFFo5h SzhghMvDdk+aUS0apJkWfFGaPf4DLwWL4SReUzyXa2l2Wc4Ek52wGUe7cvwSyYTb/R/i WJEvIkW1PbqBI6X96j3STnSe1hQ4WVM/poV3Sk0s5ZsT777KurjC31dl7LO8WJW8c9Ke 6+Arcc8IsxCapIfFBhTriOLSC4xZdfkTpB0cyougNctJBpvUm07BclvD9h1sfNg9iXLZ gxDQ== 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 p4si12530749eju.447.2020.07.05.20.21.01; Sun, 05 Jul 2020 20:21:25 -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 S1728682AbgGFDTx (ORCPT + 99 others); Sun, 5 Jul 2020 23:19:53 -0400 Received: from mail5.windriver.com ([192.103.53.11]:53030 "EHLO mail5.wrs.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728634AbgGFDTx (ORCPT ); Sun, 5 Jul 2020 23:19:53 -0400 Received: from ALA-HCB.corp.ad.wrs.com (ala-hcb.corp.ad.wrs.com [147.11.189.41]) by mail5.wrs.com (8.15.2/8.15.2) with ESMTPS id 0663GhXp022250 (version=TLSv1 cipher=DHE-RSA-AES256-SHA bits=256 verify=FAIL); Sun, 5 Jul 2020 20:16:54 -0700 Received: from pek-lpg-core1-vm1.wrs.com (128.224.156.106) by ALA-HCB.corp.ad.wrs.com (147.11.189.41) with Microsoft SMTP Server id 14.3.487.0; Sun, 5 Jul 2020 20:16:32 -0700 From: To: , , , , , CC: , , Subject: [PATCH v3] kthread: Work could not be queued when worker being destroyed Date: Sun, 5 Jul 2020 09:30:18 +0800 Message-ID: <20200705013018.7375-1-qiang.zhang@windriver.com> X-Mailer: git-send-email 2.24.1 MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Zhang Qiang Before the work is put into the queue of the worker thread, the state of the worker thread needs to be detected,because the worker thread may be in the destruction state at this time. Signed-off-by: Zhang Qiang Suggested-by: Petr Mladek Reviewed-by: Petr Mladek --- v1->v2: Add warning information for condition "!worker->task". v2->v3: Modify submission information and add "Reviewed-by" tags. kernel/kthread.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/kernel/kthread.c b/kernel/kthread.c index bfbfa481be3a..cac5184ffd86 100644 --- a/kernel/kthread.c +++ b/kernel/kthread.c @@ -791,6 +791,9 @@ static inline bool queuing_blocked(struct kthread_worker *worker, { lockdep_assert_held(&worker->lock); + if (WARN_ON(!worker->task)) + return true; + return !list_empty(&work->node) || work->canceling; } -- 2.24.1