Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp592258ybz; Wed, 15 Apr 2020 14:43:46 -0700 (PDT) X-Google-Smtp-Source: APiQypLP0XSvR3GPdeKCCmcpHRThSY2IDGrqUfOZiy4Va4n2EnAc7wyqLc+uFkitMJVZgOH33F4o X-Received: by 2002:a17:906:4e8a:: with SMTP id v10mr6767266eju.63.1586987026129; Wed, 15 Apr 2020 14:43:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586987026; cv=none; d=google.com; s=arc-20160816; b=KjaGym1L7MzJPan2/lOeXQSZkqh9ItgyD5uicmvo1EDB+Dz4IK1ZnUrlzJb6lYeBR/ 4zR6brccQIMO0MMVylRXEh5Zos+EsupUONDIbIn3BujYsAyOguaTMhonmFcEHEPiKv2M zh8j/XB/ySg2KmDIPuqjEhltURfhhZu9Txq+wG0auPfL3GwDPkBHLSzTARwelT4NKbez 4muaUGdtv3QP/88rjrx13VNydoYbZQ5i51lhYL9sXvkFzuVmtYc7DQsxP+7YNs8MZX7Q lrOnhjU5x0+se4/0/3P0rJZ8nltHPGZEsNnxg9SR1yJhBaSEBVjJcA+nZkWP4rmAkCzq XEJA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=UfGDLOb7Hn4p9fa8pj92uT3BQW7WrZHdumVexk90vT4=; b=wBnlE/FQvIb7p6aL7pLNZl9r6ilLxShSmHsO85f2E9cKYZ29fft5qwsW9NqGLePcia 5225HITkgqYI5hZamr1I9EF6rBnpAsbD0cwL4qBRqVovlzISnTbzjyHjA4RXVRJrSbTb bAQzDsTt5f4Q9dEU/7JzGvM7MyOzf5aNpZEpl4IDUkL/wu4GdAKMx+sCOQF77MnE5WVK GHZOmdvTeSw7ADWXA713DyBuy/6FZoiqWdvANS1OPkZidNkPMlgnujwcWoDz/7HCYumP YQkIHW2qR6LO2zi34SPr1IBHcXg8fmfK1+oGtbs7fedi5zVGJChhHcJlQtb7QuH8nQpZ KR7A== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w19si6679331edx.386.2020.04.15.14.43.22; Wed, 15 Apr 2020 14:43:46 -0700 (PDT) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2437758AbgDNPPr (ORCPT + 99 others); Tue, 14 Apr 2020 11:15:47 -0400 Received: from foss.arm.com ([217.140.110.172]:57714 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2406985AbgDNPGx (ORCPT ); Tue, 14 Apr 2020 11:06:53 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 88D53113E; Tue, 14 Apr 2020 08:06:52 -0700 (PDT) Received: from e107158-lin.cambridge.arm.com (e107158-lin.cambridge.arm.com [10.1.195.21]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 73C593F73D; Tue, 14 Apr 2020 08:06:50 -0700 (PDT) From: Qais Yousef To: Ingo Molnar , Peter Zijlstra Cc: Qais Yousef , Juri Lelli , Vincent Guittot , Dietmar Eggemann , Steven Rostedt , Ben Segall , Mel Gorman , Andrew Morton , Thomas Gleixner , Yury Norov , Paul Turner , Alexey Dobriyan , Josh Don , Pavan Kondeti , linux-kernel@vger.kernel.org Subject: [PATCH 4/4] sched/rt: Better distribute tasks that wakeup simultaneously Date: Tue, 14 Apr 2020 16:05:56 +0100 Message-Id: <20200414150556.10920-5-qais.yousef@arm.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200414150556.10920-1-qais.yousef@arm.com> References: <20200414150556.10920-1-qais.yousef@arm.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org If multiple RT tasks of the same priority wakeup simultaneously, select_task_rt_rt() will always return the same CPU for all tasks because find_lowest_rq() always returns the first cpu in the lowest_mask. Use cpumask_any_and() to randomize the selection, hence better distribute the tasks. This helps alleviate the thundering herd issue described here when multiple tasks of the same priority wake up simultaneously: https://lore.kernel.org/lkml/20200219140243.wfljmupcrwm2jelo@e107158-lin/ Signed-off-by: Qais Yousef CC: Juri Lelli CC: Vincent Guittot CC: Dietmar Eggemann CC: Steven Rostedt CC: Ben Segall CC: Mel Gorman CC: Andrew Morton CC: Thomas Gleixner CC: Yury Norov CC: Paul Turner CC: Alexey Dobriyan CC: Josh Don CC: Pavan Kondeti CC: linux-kernel@vger.kernel.org --- kernel/sched/rt.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/kernel/sched/rt.c b/kernel/sched/rt.c index df11d88c9895..16c7eede370a 100644 --- a/kernel/sched/rt.c +++ b/kernel/sched/rt.c @@ -1750,8 +1750,8 @@ static int find_lowest_rq(struct task_struct *task) return this_cpu; } - best_cpu = cpumask_first_and(lowest_mask, - sched_domain_span(sd)); + best_cpu = cpumask_any_and(lowest_mask, + sched_domain_span(sd)); if (best_cpu < nr_cpu_ids) { rcu_read_unlock(); return best_cpu; -- 2.17.1