From mboxrd@z Thu Jan 1 00:00:00 1970 From: Peter Zijlstra Subject: Re: [PATCH v8 5/8] cgroup/cpuset: convert cpuset_mutex to percpu_rwsem Date: Fri, 28 Jun 2019 14:45:53 +0200 Message-ID: <20190628124553.GT3419@hirez.programming.kicks-ass.net> References: <20190628080618.522-1-juri.lelli@redhat.com> <20190628080618.522-6-juri.lelli@redhat.com> Mime-Version: 1.0 Return-path: DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=merlin.20170209; h=In-Reply-To:Content-Type:MIME-Version: References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=vgfmsINpuE2ZU4+ZZYzkWKZ//l3gJpXtEC1mQPLq5So=; b=xeSn78dA2gJy8x/E56SZ6JNSh kvo8AgJJyguyKxBgDpp0JRC7yy+3DlWcrWylwFUHlg6pXwg9TCdqAxqJw8PF21Q7+KPU/0zaQDoBG Lbm1wLXUZQqL8JdNGTn3ZPqHMDdmZeVuGYj9TxBrPjBQz3ThZrM39sGLHIFs3PASN+2cYZx/JX2u9 bgJSY4mb0elp39cEyEGzrDDm9q9BRMerp4gcSAtOwI+HvrvcmdvW8flkdwM05c4Wi6N6Oud2cFWfT atPqsRnydlmqiMPMEXjefNdc6+OsvC8jKCJDRqCyYw2VICkIFYSfjDhfhHpdxeeTkMXAM4d4YXwlB Content-Disposition: inline In-Reply-To: <20190628080618.522-6-juri.lelli@redhat.com> Sender: linux-kernel-owner@vger.kernel.org List-ID: Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit To: Juri Lelli Cc: mingo@redhat.com, rostedt@goodmis.org, tj@kernel.org, linux-kernel@vger.kernel.org, luca.abeni@santannapisa.it, claudio@evidence.eu.com, tommaso.cucinotta@santannapisa.it, bristot@redhat.com, mathieu.poirier@linaro.org, lizefan@huawei.com, cgroups@vger.kernel.org On Fri, Jun 28, 2019 at 10:06:15AM +0200, Juri Lelli wrote: > @@ -2154,7 +2154,7 @@ static int cpuset_can_attach(struct cgroup_taskset *tset) > cpuset_attach_old_cs = task_cs(cgroup_taskset_first(tset, &css)); > cs = css_cs(css); > > - mutex_lock(&cpuset_mutex); > + percpu_down_read(&cpuset_rwsem); > > /* allow moving tasks into an empty cpuset if on default hierarchy */ > ret = -ENOSPC; > @@ -2178,7 +2178,7 @@ static int cpuset_can_attach(struct cgroup_taskset *tset) > cs->attach_in_progress++; > ret = 0; > out_unlock: > - mutex_unlock(&cpuset_mutex); > + percpu_up_read(&cpuset_rwsem); > return ret; > } > > @@ -2188,9 +2188,9 @@ static void cpuset_cancel_attach(struct cgroup_taskset *tset) > > cgroup_taskset_first(tset, &css); > > - mutex_lock(&cpuset_mutex); > + percpu_down_read(&cpuset_rwsem); > css_cs(css)->attach_in_progress--; > - mutex_unlock(&cpuset_mutex); > + percpu_up_read(&cpuset_rwsem); > } These are the only percpu_down_read()s introduced in this patch; are we sure this is correct? Specifically, what serializes ->attach_in_progress?