Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp1681228ybz; Thu, 16 Apr 2020 13:34:37 -0700 (PDT) X-Google-Smtp-Source: APiQypIGr8L1s6r9MspW2rdlpmIQptANio5BF4AmGahtmgGtriHz5ktoKOmwo/y+Zuw9DGbUGVZv X-Received: by 2002:a05:6402:b47:: with SMTP id bx7mr27089edb.374.1587069277221; Thu, 16 Apr 2020 13:34:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587069277; cv=none; d=google.com; s=arc-20160816; b=sT1vKMMl4rzz8tPy522KABxI4KnaXAxecAmiA/EqK78rX8buYSg8kRdAI+dq6uOf9M sGIFESQl3z6exY1SVLVZXSYd8ycM81rMac5K8ker78RHZmV/4uQnmbhp7STdYxtQ5q+C 48TElU3rxrIOfIC+BmkUZcgXx5ny3+qDB4jiPP4ygcmXoyZo1QXVRUIkqK21+JhNC3d5 XUUioBLmrlxyuDZHc0lySTU06M1yCqYHb1SvXhcYZcuhveHVLAtZUTii4aGkTZXFriw5 qF4kctds7pwsMVMQwGknW7c04nY2lnuoZRfMXslrBds2dqDZ2FXk9GZsQOg+pzWG4wWF gDyw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=pW5Iiqduz9e8InSGZdM7p9KctT5FX7Gd16K+jvo1GPs=; b=TXX/YmM57sATE+obE/eX1FFfZJJ4DqJQ1Yd6cp2rdOrNFNSF6gFO1r06niWICN5QnV 3PVgHNnQJ1+2EZ8MKR4hcAVltr6AqAECMuSDXTHTknSBftV/H1KkRe+KInVJcEgzWk49 S73oV0jcmU+a1cIsH5w0VU48eWaWSFR6mqMwxIv0xkpLyl522or7orhsrvToXLHHOouT sCsuEBvh41P+Y4VKCe63fOKMbHx5wjweXr9q++FqdXIdaqFMi19ElaNMy5hcoJPNYy3G DLN3nbhpRHLYbEFP+rHCkrgmW4KCP4i1WRtMCwq8q63fo+G4Gt3X8mjBM3hlvOvindJb chhQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=C13ngBRd; 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 f22si11885520eje.123.2020.04.16.13.34.14; Thu, 16 Apr 2020 13:34:37 -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; dkim=pass header.i=@kernel.org header.s=default header.b=C13ngBRd; 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 S2438808AbgDPPVw (ORCPT + 99 others); Thu, 16 Apr 2020 11:21:52 -0400 Received: from mail.kernel.org ([198.145.29.99]:60602 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2898599AbgDPNqc (ORCPT ); Thu, 16 Apr 2020 09:46:32 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 55AEC21974; Thu, 16 Apr 2020 13:46:31 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1587044791; bh=onF0Q3ck23MEhrOfebvcgKutD7Bobnp4aqHWm2/ayD4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=C13ngBRdOcowph6JBYB4z0vz2JeqqxDLdLSuflSEmkTCsSz7n1uyFmN5PP2+79n6z cMUiA0mYNmaYptkjvMNtb7A+Ptn+EgO+tZlFjDzwK1xyqnAlnrxWePpdhy5ozitWTO DGaljyihOf+3cqEEBSz/sgbhNjM7EBtT/KG1Cim8= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Christian Borntraeger , Vincent Guittot , "Peter Zijlstra (Intel)" , Dietmar Eggemann Subject: [PATCH 5.4 104/232] sched/fair: Fix enqueue_task_fair warning Date: Thu, 16 Apr 2020 15:23:18 +0200 Message-Id: <20200416131328.097402688@linuxfoundation.org> X-Mailer: git-send-email 2.26.1 In-Reply-To: <20200416131316.640996080@linuxfoundation.org> References: <20200416131316.640996080@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Vincent Guittot commit fe61468b2cbc2b7ce5f8d3bf32ae5001d4c434e9 upstream. When a cfs rq is throttled, the latter and its child are removed from the leaf list but their nr_running is not changed which includes staying higher than 1. When a task is enqueued in this throttled branch, the cfs rqs must be added back in order to ensure correct ordering in the list but this can only happens if nr_running == 1. When cfs bandwidth is used, we call unconditionnaly list_add_leaf_cfs_rq() when enqueuing an entity to make sure that the complete branch will be added. Similarly unthrottle_cfs_rq() can stop adding cfs in the list when a parent is throttled. Iterate the remaining entity to ensure that the complete branch will be added in the list. Reported-by: Christian Borntraeger Signed-off-by: Vincent Guittot Signed-off-by: Peter Zijlstra (Intel) Reviewed-by: Dietmar Eggemann Tested-by: Christian Borntraeger Tested-by: Dietmar Eggemann Cc: stable@vger.kernel.org Cc: stable@vger.kernel.org #v5.1+ Link: https://lkml.kernel.org/r/20200306135257.25044-1-vincent.guittot@linaro.org Signed-off-by: Greg Kroah-Hartman --- kernel/sched/fair.c | 26 ++++++++++++++++++++++---- 1 file changed, 22 insertions(+), 4 deletions(-) --- a/kernel/sched/fair.c +++ b/kernel/sched/fair.c @@ -3927,6 +3927,7 @@ static inline void check_schedstat_requi #endif } +static inline bool cfs_bandwidth_used(void); /* * MIGRATION @@ -4005,10 +4006,16 @@ enqueue_entity(struct cfs_rq *cfs_rq, st __enqueue_entity(cfs_rq, se); se->on_rq = 1; - if (cfs_rq->nr_running == 1) { + /* + * When bandwidth control is enabled, cfs might have been removed + * because of a parent been throttled but cfs->nr_running > 1. Try to + * add it unconditionnally. + */ + if (cfs_rq->nr_running == 1 || cfs_bandwidth_used()) list_add_leaf_cfs_rq(cfs_rq); + + if (cfs_rq->nr_running == 1) check_enqueue_throttle(cfs_rq); - } } static void __clear_buddies_last(struct sched_entity *se) @@ -4589,11 +4596,22 @@ void unthrottle_cfs_rq(struct cfs_rq *cf break; } - assert_list_leaf_cfs_rq(rq); - if (!se) add_nr_running(rq, task_delta); + /* + * The cfs_rq_throttled() breaks in the above iteration can result in + * incomplete leaf list maintenance, resulting in triggering the + * assertion below. + */ + for_each_sched_entity(se) { + cfs_rq = cfs_rq_of(se); + + list_add_leaf_cfs_rq(cfs_rq); + } + + assert_list_leaf_cfs_rq(rq); + /* Determine whether we need to wake up potentially idle CPU: */ if (rq->curr == rq->idle && rq->cfs.nr_running) resched_curr(rq);