Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp1608778ybv; Sun, 23 Feb 2020 10:40:43 -0800 (PST) X-Google-Smtp-Source: APXvYqz7Os7Kv72rVwc+ll5TjcBkyvAq6sBBdutwxKxODlnCKhbL38aKmhVYDCemT+dSYTl0jJDC X-Received: by 2002:aca:1b11:: with SMTP id b17mr10086136oib.45.1582483243260; Sun, 23 Feb 2020 10:40:43 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582483243; cv=none; d=google.com; s=arc-20160816; b=cWXrsFLkIib/E86szZMSac2+QJUCjL1mtbIMdMcZ27CDsS8aIQAqqqTUtbxMYKN7Aw DK4u0HavJ6yhG7u6I/4VTvmbBgo3fswAO2rqkMMaFD+IllY8m5pefF7F+k1Ljj3A12St RZmetZCQufObw1rZjuOEyWtoD0sgm7MSfMzOV9jhB5EGjLhSYT9HNk5Yi0z36e9Cq1Lu YAy1+g3CjkU4nTDRkU0muMEyIdV97jP/0AzB7C6U+hYurXKx5wTxySyBVjFVlRr6jAr+ 4MRyDmcyg1as6cgVdWPJlubVVLQxIEvj9VwkuuDjktYBYJLuPyFCBT7iPIl7fCdb2vkW i4lw== 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=AzKR9Tc4tUbQ0AS2KT7Kq5d1ZpOYjPbBjNxaLAsM5DA=; b=Ak6r6sT555yOfCEIFqQXYuB5Qra7fW7IpPgH3SwIWzY+5YUs+HuQw4KDEgnT1z9fyv Lxk10gbhjLB1iRqG73Q9OFfH5FA5v8Zm/R+2aPpMxPCiR+j3/6WUnmjXo4Hp7rOhU1hN LA6isZ8mMZgcBrAyF14CFjBC2XeOk9PJgny5ZTcoXEnESXCJIVpA7jekITAXra0cmeCl FAL5MDWlOMZ0+xTFavyEVVYcQ80JULIN+hBX72ho1M+kciBszi9JXYR62C/27L+0kcJF 4rLt5dNC+O92au6MHdYU3YGGFlKJ+O7OIl1QF7107DI0R3fugWKyE2XsViJyET+ehT4B ehRA== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a10si4223645oia.232.2020.02.23.10.40.31; Sun, 23 Feb 2020 10:40:43 -0800 (PST) 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727221AbgBWSkQ (ORCPT + 99 others); Sun, 23 Feb 2020 13:40:16 -0500 Received: from foss.arm.com ([217.140.110.172]:50528 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727210AbgBWSkP (ORCPT ); Sun, 23 Feb 2020 13:40:15 -0500 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 0D14E106F; Sun, 23 Feb 2020 10:40:15 -0800 (PST) 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 980F93F703; Sun, 23 Feb 2020 10:40:13 -0800 (PST) From: Qais Yousef To: Ingo Molnar , Peter Zijlstra , Steven Rostedt , Dietmar Eggemann , Pavan Kondeti Cc: Juri Lelli , Vincent Guittot , Ben Segall , Mel Gorman , linux-kernel@vger.kernel.org, Qais Yousef Subject: [PATCH v2 4/6] sched/rt: allow pulling unfitting task Date: Sun, 23 Feb 2020 18:39:59 +0000 Message-Id: <20200223184001.14248-5-qais.yousef@arm.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20200223184001.14248-1-qais.yousef@arm.com> References: <20200223184001.14248-1-qais.yousef@arm.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When implemented RT Capacity Awareness; the logic was done such that if a task was running on a fitting CPU, then it was sticky and we would try our best to keep it there. But as Steve suggested, to adhere to the strict priority rules of RT class; allow pulling an RT task to unfitting CPU to ensure it gets a chance to run ASAP. Suggested-by: Steven Rostedt Fixes: 804d402fb6f6 ("sched/rt: Make RT capacity-aware") LINK: https://lore.kernel.org/lkml/20200203111451.0d1da58f@oasis.local.home/ Signed-off-by: Qais Yousef --- kernel/sched/rt.c | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/kernel/sched/rt.c b/kernel/sched/rt.c index e48d7c215aee..9ae8a9fabe8b 100644 --- a/kernel/sched/rt.c +++ b/kernel/sched/rt.c @@ -1656,8 +1656,7 @@ static void put_prev_task_rt(struct rq *rq, struct task_struct *p) static int pick_rt_task(struct rq *rq, struct task_struct *p, int cpu) { if (!task_running(rq, p) && - cpumask_test_cpu(cpu, p->cpus_ptr) && - rt_task_fits_capacity(p, cpu)) + cpumask_test_cpu(cpu, p->cpus_ptr)) return 1; return 0; -- 2.17.1