Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp591632ybz; Wed, 15 Apr 2020 14:42:55 -0700 (PDT) X-Google-Smtp-Source: APiQypJ2XwibVTn8qiVkHO3ACKNmmaeRThJOjeRxQJrRnDSpgZIXnDTy39d+O2ft8xwdHHYT7ZQb X-Received: by 2002:a05:6402:1bcc:: with SMTP id ch12mr26250185edb.55.1586986975057; Wed, 15 Apr 2020 14:42:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586986975; cv=none; d=google.com; s=arc-20160816; b=BcqwPq4T37h0oumjw870GGoo1sYbFBFGzqtVBx5X2NJSmhX+KjeZCuztFPpqApo/1M oeqV5vm6AwmwZj2rO9LfBV4nAcMkkrX8+mJRs5GbSrdyzkfLARLYgGiNHcrdWhkgS890 WZsdQwrPtRFQktZBl+19BR4QVBy6RrhDacVssiNGe6rDTrCqJqQ70f8tHd5Xh6WBhpyj qUqA+ovxcnSjoBFCKLB2YDY83YRgjkJqehKvcGqVUC1lzp4DyekcsdRA/YDYgzlTP4Mw bOMk6ukwxLuHYBhVKNTe/0d9/NlSBG65llNd4889qtlJNU9B9Zoo0oW3v/q/4hVnaWD3 esbA== 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=IsWonf7PPR+eOwuwPX/lONrDpwjOa3w3cobpX2hppAE=; b=uM853gTeWDjxZf1+BURu2qdFQvg1uGxmMO9yIqWeLrdpjrXcpqIqPP4p4bThOJeqkm XLPVYfIKn9LZEzcyNwG1dS2PZTt92ENDPTshShPnuKRVLQyTBdN9yzhTHlYqXGy1IFy/ JJ23sYAc4VH1bfTvi7rrxrQHFxWhTju9G4HICBGSFrtipj79aKepOUCRG7IGBC/B9Npr 6rX4Inhay5RRKuDyTy9r15C1eYtXvFsRcTEjOuZkYoFWLMzBF0arJZgpRpECbHePmSHv h1Nn+6HzLWghn/lmJPrAc3g3vFS0mGMVAGEOFHlwFiTUujrkqpiB7ox+yQrzNBUDic2c kMQQ== 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 s10si12542683ejb.45.2020.04.15.14.42.31; Wed, 15 Apr 2020 14:42:55 -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 S2407295AbgDNPGq (ORCPT + 99 others); Tue, 14 Apr 2020 11:06:46 -0400 Received: from foss.arm.com ([217.140.110.172]:57612 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2407283AbgDNPGi (ORCPT ); Tue, 14 Apr 2020 11:06:38 -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 1718E30E; Tue, 14 Apr 2020 08:06:38 -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 F2AF23F73D; Tue, 14 Apr 2020 08:06:35 -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 0/4] sched/rt: Distribute tasks in find_lowest_rq() Date: Tue, 14 Apr 2020 16:05:52 +0100 Message-Id: <20200414150556.10920-1-qais.yousef@arm.com> X-Mailer: git-send-email 2.17.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Now that we have a proper function that returns a 'random' CPU in a mask [1] utilize that in find_lowest_rq() to solve the thundering herd issue described in this thread https://lore.kernel.org/lkml/20200219140243.wfljmupcrwm2jelo@e107158-lin/ But as a pre-amble, I noticed that the new cpumask_any_and_distribute() is actually an alias for cpumask_any_and() which is documented as returning a 'random' cpu but actually just does cpumask_first_and(). The first 3 patches cleanup the API so that the whole family of cpumask_any*() take advantage of the new 'random' behavior and in patch 4 I convert the cpumask_first_and() --> cpumask_any_and() in find_lowest_rq() to allow to better distribute the RT tasks that wake up simultaneously. [1] https://lore.kernel.org/lkml/20200311010113.136465-1-joshdon@google.com/ 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 Qais Yousef (4): cpumask: Rename cpumask_any_and_distribute cpumask: Make cpumask_any() truly random cpumask: Convert cpumask_any_but() to the new random function sched/rt: Better distribute tasks that wakeup simultaneously include/linux/cpumask.h | 33 ++++++----------- kernel/sched/core.c | 2 +- kernel/sched/rt.c | 4 +- lib/cpumask.c | 82 +++++++++++++++++++++++++++-------------- 4 files changed, 68 insertions(+), 53 deletions(-) -- 2.17.1