Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp28608479rwd; Tue, 4 Jul 2023 23:23:57 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ49JxjrtN3Zc8IfoiAxAvbXcTThNiVXZHd+9W37sHilPq5btLPJsZzgWkPALuyfc73rYya1 X-Received: by 2002:a05:6870:d98:b0:1b0:3118:1e83 with SMTP id mj24-20020a0568700d9800b001b031181e83mr12667494oab.49.1688538236934; Tue, 04 Jul 2023 23:23:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1688538236; cv=none; d=google.com; s=arc-20160816; b=NWbHmy2R66rYTC2a6wqQgRVpZ7bSO53KU27ykvpIqWUiPv2Oe+34HhjbLmG48xOzFD 72/4eT633Qa62iP8X+myBM2Md3jIyR99XUBaD4BuUb9Ql8cM+E3bllAyl//XSUV70E6b Zxm+GteBwshBCheJR1OL6rGZNj3DeLMJBBiDS88y6h63XBNKuzWzu8PG8b4dIcXC3Wd6 24glwIQ12so3cXkwxZ6yMu78LUgxDi2RRKWYQmfJwxfipRASQIMQEyTOTvhFw/tenMhv ljvxGp5arKbha2Q+ziBXrotsyoPemRQoZEChYxBnTXCeqBbOxnzIHD5B5C18/R4k4ilT 8CDA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=4EadJHf/WKEF16AnZfqD42QEt4mNmTmakOqqz7gMutQ=; fh=2DFovMH9v9KoZV5FqczdfVFlI6N9+J5jXCGI5BFvqfs=; b=o4Cc8XCLG5DmHLW2hq1NEAoEDYBLkNpxvy9XF6OhMj1kR3jjgWIgQqX3c1cgvcB2Iv zpfCmkHc23mHO3l/V0hUUz14ZqugdEv0R8cf7gyuqSOd16gqeMMkHKiOU1rj71WYLVjW dxqqdazQCu6SaEgxeyQxwigAkdyM7AmeokAe7ToKQrAKs3FNS/X6iOE5/5++M0WVjlA+ F6F/kegwwiV2ENfyUqnZLt/BQyOhNcFG/MWIiD4jfi7mDZ6MZQNlmzkuKpDEAxifPG6W 6bTeeEJ0evPxIlBdEzw4+fqlw7X9kuNcIzGreYM3erdEjJFVAKyXwU9FHw4QoDIL53Vq dwLA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id x24-20020a17090ab01800b0026121515137si959485pjq.45.2023.07.04.23.23.44; Tue, 04 Jul 2023 23:23:56 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231344AbjGEF4N (ORCPT + 99 others); Wed, 5 Jul 2023 01:56:13 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59762 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229801AbjGEF4M (ORCPT ); Wed, 5 Jul 2023 01:56:12 -0400 Received: from szxga01-in.huawei.com (szxga01-in.huawei.com [45.249.212.187]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B0F70B2; Tue, 4 Jul 2023 22:56:08 -0700 (PDT) Received: from canpemm500002.china.huawei.com (unknown [172.30.72.57]) by szxga01-in.huawei.com (SkyGuard) with ESMTP id 4Qwpjg0YM2ztQV4; Wed, 5 Jul 2023 13:53:11 +0800 (CST) Received: from [10.174.151.185] (10.174.151.185) by canpemm500002.china.huawei.com (7.192.104.244) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.27; Wed, 5 Jul 2023 13:56:02 +0800 Subject: Re: [PATCH] cgroup/cpuset: simplify the percpu kthreads check in update_tasks_cpumask() To: Waiman Long CC: , , , , References: <20230704113049.1019118-1-linmiaohe@huawei.com> From: Miaohe Lin Message-ID: <33c2bf85-6def-fce9-9ea7-3b3e80db67b7@huawei.com> Date: Wed, 5 Jul 2023 13:56:02 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.6.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 8bit X-Originating-IP: [10.174.151.185] X-ClientProxiedBy: dggems706-chm.china.huawei.com (10.3.19.183) To canpemm500002.china.huawei.com (7.192.104.244) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.3 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,RCVD_IN_MSPIKE_H5,RCVD_IN_MSPIKE_WL,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2023/7/5 11:14, Waiman Long wrote: > On 7/4/23 07:30, Miaohe Lin wrote: >> kthread_is_per_cpu() can be called directly without checking whether >> PF_KTHREAD is set in task->flags. So remove PF_KTHREAD check to make >> code more concise. >> >> Signed-off-by: Miaohe Lin >> --- >>   kernel/cgroup/cpuset.c | 2 +- >>   1 file changed, 1 insertion(+), 1 deletion(-) >> >> diff --git a/kernel/cgroup/cpuset.c b/kernel/cgroup/cpuset.c >> index 58e6f18f01c1..601c40da8e03 100644 >> --- a/kernel/cgroup/cpuset.c >> +++ b/kernel/cgroup/cpuset.c >> @@ -1230,7 +1230,7 @@ static void update_tasks_cpumask(struct cpuset *cs, struct cpumask *new_cpus) >>               /* >>                * Percpu kthreads in top_cpuset are ignored >>                */ >> -            if ((task->flags & PF_KTHREAD) && kthread_is_per_cpu(task)) >> +            if (kthread_is_per_cpu(task)) >>                   continue; >>               cpumask_andnot(new_cpus, possible_mask, cs->subparts_cpus); >>           } else { > > The initial intention was to ignore only percpu kthreads. The current code likely ignore all the kthreads. Removing the PF_KTHREAD flag, however, may introduce unexpected regression at this point. I would like to hold off for now until more investigation are done. IMHO, the current code will ignore only percpu kthreads: 1.If PF_KTHREAD is set in task->flags, this patch doesn't make any difference. 2.If PF_KTHREAD is not set in task->flags, kthread_is_per_cpu will *always return false*. So this patch doesn't make any functional change. bool kthread_is_per_cpu(struct task_struct *p) { struct kthread *kthread = __to_kthread(p); if (!kthread) return false; .... } static inline struct kthread *__to_kthread(struct task_struct *p) { void *kthread = p->worker_private; if (kthread && !(p->flags & PF_KTHREAD)) ^^^^^^^^^^^^^^^^^^^^^^ PF_KTHREAD is not set, so kthread = NULL. kthread = NULL; return kthread; } Or am I miss something? Thanks for comment and review.