Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp1395322ybb; Sat, 11 Apr 2020 02:23:27 -0700 (PDT) X-Google-Smtp-Source: APiQypLLcjLId1s8g1akH3KGxVN1SAaOSzSNhOLVCmqMFmiVLnwbYpDQ5TZjfk3R6/N8A3SM/EEr X-Received: by 2002:aed:208e:: with SMTP id 14mr2799237qtb.335.1586597007552; Sat, 11 Apr 2020 02:23:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586597007; cv=none; d=google.com; s=arc-20160816; b=VI3UTUu96CkC/EBpOpKOoFoPBsdwFkgwZ46uJuOnyijno9NYYGOS33IGXHl1Gaf0qO YPMBE2cdXeCA3h49lWjrICgabLlXy9cR1PJkI1fvAS0uJ6ppAHcAVCxtDy5sUJs7cp8D z1WqhWvCFGtB7LtO7aENt2fjrPNGR2OHaBsUem0/syWVY9upl4zKMRzeerPX725/jdbV u0JhghckUmdFVRTQcWGIbuusSanCKcum0tghZuvgbey6i7dTnEyrZv7i3HwBcBqOjMO1 +TevUQlM1nd0hs0s5pEduwoDo81KFzecB8hQmtR3HcwlZ1XjtGV31RlQa8oXUVaaVzfq 1Xpg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=bftAKV8qWl1gAE/CYTUngK2ZdcfBBFJCKPiTJJxSLcE=; b=YWoKOEJTPgiKYWDk8woho0/bo0TxAA/SKeBYH7juNG06vqTFROHS9q3U6orG1934If fGg1SL3dA3cV7s9o4UmD4po/db+VClObj9sxa4w+cd+/HKvmPcJ6dAOiwzZYwQmwSXPh uEX2WgdxO8CMJf/nOxJKoWMv6FyxuhxhGy143zgt/j4uUuKRqm4gRxcJMI+WR1mwxZKt yXWdLgR92naSeZAFP2jVA6DQ8HTHBkGFHbXzOHgAxCdwG2kykXIoEQr9r9fxQAak5uzS fuDT+7KoiBcNmg2xLCepbBpJr8WfXd1ZWCSYL0FEoZ1i/fcOKuotKlzJjHlHYwmGlIJL 3Kdg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x19si2745868qta.398.2020.04.11.02.23.12; Sat, 11 Apr 2020 02:23:27 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726029AbgDKJVH (ORCPT + 99 others); Sat, 11 Apr 2020 05:21:07 -0400 Received: from out30-131.freemail.mail.aliyun.com ([115.124.30.131]:35247 "EHLO out30-131.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725901AbgDKJVH (ORCPT ); Sat, 11 Apr 2020 05:21:07 -0400 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R401e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e01419;MF=rocking@linux.alibaba.com;NM=1;PH=DS;RN=9;SR=0;TI=SMTPD_---0TvC34s5_1586596838; Received: from localhost(mailfrom:rocking@linux.alibaba.com fp:SMTPD_---0TvC34s5_1586596838) by smtp.aliyun-inc.com(127.0.0.1); Sat, 11 Apr 2020 17:20:52 +0800 From: Peng Wang To: mingo@redhat.com, peterz@infradead.org, uri.lelli@redhat.com, vincent.guittot@linaro.org, dietmar.eggemann@arm.com, rostedt@goodmis.org, bsegall@google.com, mgorman@suse.de Cc: linux-kernel@vger.kernel.org Subject: [PATCH] sched/fair: Simplify the code of should_we_balance() Date: Sat, 11 Apr 2020 17:20:20 +0800 Message-Id: <245c792f0e580b3ca342ad61257f4c066ee0f84f.1586594833.git.rocking@linux.alibaba.com> X-Mailer: git-send-email 2.9.5 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org We only consider group_balance_cpu() after there is no idle cpu. So, just do comparison before return at these two cases. Signed-off-by: Peng Wang --- kernel/sched/fair.c | 16 +++++----------- 1 file changed, 5 insertions(+), 11 deletions(-) diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c index 1ea3ddd..81b2c647 100644 --- a/kernel/sched/fair.c +++ b/kernel/sched/fair.c @@ -9413,7 +9413,7 @@ static int active_load_balance_cpu_stop(void *data); static int should_we_balance(struct lb_env *env) { struct sched_group *sg = env->sd->groups; - int cpu, balance_cpu = -1; + int cpu; /* * Ensure the balancing environment is consistent; can happen @@ -9434,18 +9434,12 @@ static int should_we_balance(struct lb_env *env) if (!idle_cpu(cpu)) continue; - balance_cpu = cpu; - break; + /* Are we the first idle CPU? */ + return cpu == env->dst_cpu; } - if (balance_cpu == -1) - balance_cpu = group_balance_cpu(sg); - - /* - * First idle CPU or the first CPU(busiest) in this sched group - * is eligible for doing load balancing at this and above domains. - */ - return balance_cpu == env->dst_cpu; + /* Are we the first balance CPU of this group? */ + return group_balance_cpu(sg) == env->dst_cpu; } /* -- 2.9.5