Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp1280456pxb; Fri, 21 Jan 2022 14:13:19 -0800 (PST) X-Google-Smtp-Source: ABdhPJwjL++d+BH1iNdodzrUlQphTRtPl1Mo9NTIPm6m23NI6ngIkwIweeMRlN3jq7GuU7TvqPsS X-Received: by 2002:a17:902:c205:b0:14a:f5ba:1e10 with SMTP id 5-20020a170902c20500b0014af5ba1e10mr5780650pll.172.1642803199288; Fri, 21 Jan 2022 14:13:19 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1642803199; cv=none; d=google.com; s=arc-20160816; b=0RRIjaTFuZwrJ2Q3BVJ5r08ccgaxpGzgvYkhggeIko+m2/QuHA0A4EVrGNkKv8zV3s AYMb+xF33ejeBOWGEC33RYUuOvE0CxY4feR3qm8jGv/GKEYF169hCuigh2W1MzHOKxQN wojXYztg+PWFROqVkB1KG1pWI3UYCc8k8/I24ydzkScv3BxgcyTh79KJeqmKL3Zb4NxV EmZ4pHBs2Mhy19gaHV1v9vB7IqGnzFKLLd0HHvONZl3tafPmF4ZgX6n2SVk6r0CsGEpu x1scyz3rzsv7ygOLr5/JH4B8kIRJ3/YROlJ92gZcf3DC+JOogi4mCBCtmWr8M5FvwIa/ NhSg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:user-agent:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=34TJNw4/W0xTbQedpBACNYP+v/nLFuErBI3QihUnxYA=; b=ALnLXXaPKaJKU1q0npZrGrdu2ur6z+SGB1pnsfTyNKADDfwwRsfxzZ72UKq8C0Z2jc ivZLGociK+QKCaIxGqLYZGLxKs3fFgWHK55W2zctqVgpKyZtCi/FTGG5Pks14cav3GgM tcfcH+i+ZTiIzWBIKCwIrFeZIy10BFhghNie/QyKJaR5Ml1y1VcFf2h/Ix6qgNL9pXTh 8ZdtEiSc7BzXML5DMgifAV20OK23+FPtZIADTz0ocMff4gZHQ5gBnJ1buCq4vWWTGcJF rcPtF/msKNMwxya9df0855fovavmSyAuwAIwFcTnW/iy4wySbgQyUak8b+YOYqORNdEW Rq+Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@suse.com header.s=susede1 header.b=CL2oL11s; 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=QUARANTINE sp=NONE dis=NONE) header.from=suse.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a70si4219230pge.165.2022.01.21.14.13.06; Fri, 21 Jan 2022 14:13:19 -0800 (PST) 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=@suse.com header.s=susede1 header.b=CL2oL11s; 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=QUARANTINE sp=NONE dis=NONE) header.from=suse.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S242774AbiATOCb (ORCPT + 99 others); Thu, 20 Jan 2022 09:02:31 -0500 Received: from smtp-out2.suse.de ([195.135.220.29]:48134 "EHLO smtp-out2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235542AbiATOC2 (ORCPT ); Thu, 20 Jan 2022 09:02:28 -0500 Received: from imap2.suse-dmz.suse.de (imap2.suse-dmz.suse.de [192.168.254.74]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature ECDSA (P-521) server-digest SHA512) (No client certificate requested) by smtp-out2.suse.de (Postfix) with ESMTPS id AB7081F388; Thu, 20 Jan 2022 14:02:27 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.com; s=susede1; t=1642687347; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=34TJNw4/W0xTbQedpBACNYP+v/nLFuErBI3QihUnxYA=; b=CL2oL11sIm6GsYpC/7RLyX/oK2+E++LeDUyG+w8aimfmvFN6411HJqUB2WRcuTyJVAjkQh Nuxrm3IhXZ3K+bzZEQCv/flg8IbeBiSFtwzGpSrZ+Lk9BDV/DNcT/gBPsDHRFPQK0v6FFF 08CISQRfePNNd5sCb043RitIMLq9p1g= Received: from imap2.suse-dmz.suse.de (imap2.suse-dmz.suse.de [192.168.254.74]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature ECDSA (P-521) server-digest SHA512) (No client certificate requested) by imap2.suse-dmz.suse.de (Postfix) with ESMTPS id 8ED1213BCC; Thu, 20 Jan 2022 14:02:27 +0000 (UTC) Received: from dovecot-director2.suse.de ([192.168.254.65]) by imap2.suse-dmz.suse.de with ESMTPSA id WAJFInNr6WFoDwAAMHmgww (envelope-from ); Thu, 20 Jan 2022 14:02:27 +0000 Date: Thu, 20 Jan 2022 15:02:22 +0100 From: Michal =?iso-8859-1?Q?Koutn=FD?= To: Zhang Qiao Cc: Tejun Heo , lizefan.x@bytedance.com, hannes@cmpxchg.org, cgroups@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [Question] set_cpus_allowed_ptr() call failed at cpuset_attach() Message-ID: <20220120140222.GA27269@blackbody.suse.cz> References: <09ce5796-798e-83d0-f1a6-ba38a787bfc5@huawei.com> <4415cd09-6de3-bb2d-386d-8beb4927fb46@huawei.com> <20220119130221.GA31037@blackbody.suse.cz> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.10.1 (2018-07-13) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Jan 20, 2022 at 03:14:22PM +0800, Zhang Qiao wrote: > i think the troublesome scenario as follows: > cpuset_can_attach > down_read(cpuset_rwsem) > // check all migratees > up_read(cpuset_rwsem) > [ _cpu_down / cpuhp_setup_state ] > cpuset_attach > down_write(cpuset_rwsem) > guarantee_online_cpus() // (load cpus_attach) > sched_cpu_deactivate > set_cpu_active(cpu, false) // will change cpu_active_mask > set_cpus_allowed_ptr(cpus_attach) > __set_cpus_allowed_ptr_locked() > // (if the intersection of cpus_attach and > cpu_active_mask is empty, will return -EINVAL) > up_write(cpuset_rwsem) > schedule_work > ... > cpuset_hotplug_update_tasks > down_write(cpuset_rwsem) > up_write(cpuset_rwsem) > ... flush_work > [ _cpu_down / cpu_up_down_serialize_trainwrecks ] Thanks, a locking loophole indeed. FTR, meanwhile I noticed: a) cpuset_fork() looks buggy when CLONE_INTO_CGROUP (and dst.cpus != src.cpus), b) it'd be affected with similar hotplug race. Michal