Received: by 2002:a05:6a10:9e8c:0:0:0:0 with SMTP id y12csp380102pxx; Mon, 26 Oct 2020 10:34:33 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyIo3Wq5Q6hXmMaptSOu9csi3rr7T2mJq58NgnE1Hdt1dFH5/WqPrv7yPnPpeoK8eBDECc3 X-Received: by 2002:a50:9548:: with SMTP id v8mr16514857eda.115.1603733672913; Mon, 26 Oct 2020 10:34:32 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603733672; cv=none; d=google.com; s=arc-20160816; b=VC/DgWMDlOlNTXPm1fMIoDIEcw7z5SG1e9e7DCk7t+El6K3JpM7f1z9VhXbOWyF6PQ O2YaZ5QxDuz+9/JVQdfgzjvisTuhGWU0/DxQBoWqCAdEAljErMF7iUfSewnu2wAyG12l TlczZycnbxNhnE7UF9oRcRWEesU/DPTJ44rkjScC8PVEtA2qULR8ZiA/hpseyPZAqCiG Rq7TdAajEycLi0tnHOnmUdBJUZjoZfms68RfhaKCeAIl0bTtUbONM5576yqn1tiTMOVp nDiMPHmPyCBjAFFGKFmY024e5JaygMpMY7hLaO9bxa0czVHgDILQR1fZY+YT59TluUn3 xAXA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:sender:dkim-signature; bh=TxfXjOwfBykntP1Jpf/tQTb6j5RyS9vTmp3y0ZTz9iY=; b=iuEjxhhMCfoWbJ/VHl3Uf3m8r3ZwsXXICf8K0OJ5psHeIY9jA3kIwdDdHbLiUpO/n+ SbNqhGwjzgjgQoKSaK3yflrj80qv8B1KmJS8uxOyYlbe8TPx1IMHyy4X+xO4oFm6b73H 61oXClizMflDlqqxs5Z2AJqiSKDWf3NQHAqptnCzTCdxniZT3px5GRYPTL1Mx4asctb9 cMRIDJgJkhstTg0RJUJgd9J0FSxOEfT9GOX7duUF2Xk54vF6nGtcfvdGudlKlpRgFfdx rNPJRHjMb4Ocd5s9Ou6UpPQcXhIc5y2y4oFnXAp0Ok33TXvEW0FspeRiH/TUmvkl/2Uq Ssow== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=hj2Xzb1l; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id uz27si7477663ejb.212.2020.10.26.10.34.10; Mon, 26 Oct 2020 10:34:32 -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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=hj2Xzb1l; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1780681AbgJZNuR (ORCPT + 99 others); Mon, 26 Oct 2020 09:50:17 -0400 Received: from mail-qt1-f193.google.com ([209.85.160.193]:33233 "EHLO mail-qt1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2404378AbgJZNuQ (ORCPT ); Mon, 26 Oct 2020 09:50:16 -0400 Received: by mail-qt1-f193.google.com with SMTP id j62so6691398qtd.0 for ; Mon, 26 Oct 2020 06:50:15 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=sender:date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to; bh=TxfXjOwfBykntP1Jpf/tQTb6j5RyS9vTmp3y0ZTz9iY=; b=hj2Xzb1lS89qCPlK7eJpZN6WVDn7yEvhz2twlUFqiehOWCaTaej0//mbn2FMaBLWIn F8DmpTbIeRFOrtl/Okvy7RHEq7WiFTwBo+PePbx+LWTp2YCj4xddlYVuscGpZ3IJ+oG5 b3UES6VFcG9UeaEmeEa9bqNb87n5yviccl9+PDzNl894xBrHxr5ZNPj92FHGAHIAN8TY ooyxG4RgS33cDTqkBXOv0bc2i+LsBV1CkYSOwgTxt0QD7bG3eqnfluHeFkPQfBDRrIBs gRLxte4i3wvSPNT3sKqXiR5eJ+1OqAy2afreeXeTYcDBDdHkf0qFclAlhIc3y/aZheQ/ 65TA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:date:from:to:cc:subject:message-id :references:mime-version:content-disposition:in-reply-to; bh=TxfXjOwfBykntP1Jpf/tQTb6j5RyS9vTmp3y0ZTz9iY=; b=iJI8sNtDWNnFl/UhxLhrVZlDLd7fEnDLoGDxV4OY/Hl+c5VBGpkdG/iLXdN0qbjQRa RTfOSEvHe0TXmF5iYI27KiDr8b4SpTuiI/U2Kb9iuYO6QWAwSMIRyPnopdUeZadafpBy PR/PA9rg9w1vqwb9jgjxD++Ud6IB0GJx4rtX5PwDKq8JqNfdLOENUIVP3GtrELqwniJi 2h94da/nBz3H6uFjngzP8UYXJrb39k9m9G1CsicV/g5xTkeFLhQejo1PlwuLBs5wVZgn MIldqHE2roygieN7EQ/xh710oxPSt0EdU1NVzc4PYkhlMB+pqqBNfN3ObCz+0xiKR3ZA jzlw== X-Gm-Message-State: AOAM532KpkkfcxQQ3ID4tcFgJIlla71CbAc7sES/TgYIdhQzgh4gNdrc TLETncapBukAMDv0u6r58ZzWxuI0g128+w== X-Received: by 2002:aed:31e3:: with SMTP id 90mr1350645qth.300.1603720215250; Mon, 26 Oct 2020 06:50:15 -0700 (PDT) Received: from localhost (dhcp-48-d6-d5-c6-42-27.cpe.echoes.net. [199.96.181.106]) by smtp.gmail.com with ESMTPSA id b191sm6651842qkg.81.2020.10.26.06.50.14 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 26 Oct 2020 06:50:14 -0700 (PDT) Sender: Tejun Heo Date: Mon, 26 Oct 2020 09:50:11 -0400 From: Tejun Heo To: qiang.zhang@windriver.com Cc: pmladek@suse.com, akpm@linux-foundation.org, linux-kernel@vger.kernel.org, linux-mm@kvack.org Subject: Re: [PATCH] kthread_worker: re-set CPU affinities if CPU come online Message-ID: <20201026135011.GC73258@mtj.duckdns.org> References: <20201026065213.30477-1-qiang.zhang@windriver.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20201026065213.30477-1-qiang.zhang@windriver.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Oct 26, 2020 at 02:52:13PM +0800, qiang.zhang@windriver.com wrote: > @@ -737,8 +741,11 @@ __kthread_create_worker(int cpu, unsigned int flags, > if (IS_ERR(task)) > goto fail_task; > > - if (cpu >= 0) > + if (cpu >= 0) { > kthread_bind(task, cpu); > + worker->bind_cpu = cpu; > + cpuhp_state_add_instance_nocalls(kworker_online, &worker->cpuhp_node); > + } > > worker->flags = flags; > worker->task = task; ... > +static int kworker_cpu_online(unsigned int cpu, struct hlist_node *node) > +{ > + struct kthread_worker *worker = hlist_entry(node, struct kthread_worker, cpuhp_node); > + struct task_struct *task = worker->task; > + > + if (cpu == worker->bind_cpu) > + WARN_ON_ONCE(set_cpus_allowed_ptr(task, cpumask_of(cpu)) < 0); > + return 0; > +} I don't think this works. The kthread may have changed its binding while running using set_cpus_allowed_ptr() as you're doing above. Besides, when a cpu goes offline, the bound kthread can fall back to other cpus but its cpu mask isn't cleared, is it? Thanks. -- tejun