Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752823AbYLRRxw (ORCPT ); Thu, 18 Dec 2008 12:53:52 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1752822AbYLRRxG (ORCPT ); Thu, 18 Dec 2008 12:53:06 -0500 Received: from e28smtp04.in.ibm.com ([59.145.155.4]:51196 "EHLO e28smtp04.in.ibm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752824AbYLRRxE (ORCPT ); Thu, 18 Dec 2008 12:53:04 -0500 From: Vaidyanathan Srinivasan Subject: [PATCH v7 3/8] sched: favour lower logical cpu number for sched_mc balance To: Linux Kernel , Suresh B Siddha , Venkatesh Pallipadi , Peter Zijlstra Cc: Ingo Molnar , Dipankar Sarma , Balbir Singh , Vatsa , Gautham R Shenoy , Andi Kleen , David Collier-Brown , Tim Connors , Max Krasnyansky , Gregory Haskins , Pavel Machek , Andrew Morton , Vaidyanathan Srinivasan Date: Thu, 18 Dec 2008 23:26:16 +0530 Message-ID: <20081218175615.29812.70736.stgit@drishya.in.ibm.com> In-Reply-To: <20081218175313.29812.4781.stgit@drishya.in.ibm.com> References: <20081218175313.29812.4781.stgit@drishya.in.ibm.com> User-Agent: StGIT/0.14.2 MIME-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Just in case two groups have identical load, prefer to move load to lower logical cpu number rather than the present logic of moving to higher logical number. find_busiest_group() tries to look for a group_leader that has spare capacity to take more tasks and freeup an appropriate least loaded group. Just in case there is a tie and the load is equal, then the group with higher logical number is favoured. This conflicts with user space irqbalance daemon that will move interrupts to lower logical number if the system utilisation is very low. Signed-off-by: Vaidyanathan Srinivasan Acked-by: Balbir Singh --- kernel/sched.c | 4 ++-- 1 files changed, 2 insertions(+), 2 deletions(-) diff --git a/kernel/sched.c b/kernel/sched.c index 16897ab..0b9bbbd 100644 --- a/kernel/sched.c +++ b/kernel/sched.c @@ -3264,7 +3264,7 @@ find_busiest_group(struct sched_domain *sd, int this_cpu, */ if ((sum_nr_running < min_nr_running) || (sum_nr_running == min_nr_running && - first_cpu(group->cpumask) < + first_cpu(group->cpumask) > first_cpu(group_min->cpumask))) { group_min = group; min_nr_running = sum_nr_running; @@ -3280,7 +3280,7 @@ find_busiest_group(struct sched_domain *sd, int this_cpu, if (sum_nr_running <= group_capacity - 1) { if (sum_nr_running > leader_nr_running || (sum_nr_running == leader_nr_running && - first_cpu(group->cpumask) > + first_cpu(group->cpumask) < first_cpu(group_leader->cpumask))) { group_leader = group; leader_nr_running = sum_nr_running; -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/