From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753818AbbERNHM (ORCPT ); Mon, 18 May 2015 09:07:12 -0400 Received: from casper.infradead.org ([85.118.1.10]:45518 "EHLO casper.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752022AbbERNHC convert rfc822-to-8bit (ORCPT ); Mon, 18 May 2015 09:07:02 -0400 Message-ID: <1431954418.3322.3.camel@twins> Subject: Re: [RFC][PATCH 4/4] sched, numa: Ignore pinned tasks From: Peter Zijlstra To: Srikar Dronamraju Cc: mingo@kernel.org, riel@redhat.com, dedekind1@gmail.com, linux-kernel@vger.kernel.org, mgorman@suse.de, rostedt@goodmis.org, juri.lelli@arm.com Date: Mon, 18 May 2015 15:06:58 +0200 In-Reply-To: <20150518130050.GA2934@linux.vnet.ibm.com> References: <20150515154333.712161952@infradead.org> <20150515154833.726258767@infradead.org> <20150518130050.GA2934@linux.vnet.ibm.com> Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7BIT X-Mailer: Evolution 3.10.4-0ubuntu2 Mime-Version: 1.0 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 2015-05-18 at 18:30 +0530, Srikar Dronamraju wrote: > > > > static void account_numa_dequeue(struct rq *rq, struct task_struct *p) > > { > > + if (p->nr_cpus_allowed == 1) { > > + rq->nr_pinned_running--; > > + WARN_ON_ONCE(p->numa_preferred_nid != -1); > > + } > > rq->nr_numa_running -= (p->numa_preferred_nid != -1); > > rq->nr_preferred_running -= (p->numa_preferred_nid == task_node(p)); > > } > > > Shouldnt we reset p->numa_preferred_nid when we are setting the allowed > cpus in set_cpus_allowed_common()? > > Otherwise if an process is set a preferred node based on its numa faults > but then is pinned to a different cpu, then we can see this warning.:w! We should never get preferred_nid set when nr_cpus_allowed == 1, see the hunk that changes task_tick_numa. So we set preferred = -1 on pinning, do not partake in numa balancing while this is so, therefore it should still be so when we dequeue, right?