Received: by 2002:a25:683:0:0:0:0:0 with SMTP id 125csp648254ybg; Wed, 3 Jun 2020 09:54:17 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwdmA7J12EKgnb5/m7vCOiWSnHXg0K9WXAAS6PfPD/ijjMsxl/SwLjPcKGwjoZVnddBx6ts X-Received: by 2002:a50:d6d0:: with SMTP id l16mr330860edj.317.1591203257047; Wed, 03 Jun 2020 09:54:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1591203257; cv=none; d=google.com; s=arc-20160816; b=JboQCoVrBPOdK9wyoqh4/r3/kZ5aRbRk5A3Nxsoiewp/ocYOpEkJkArWFNICK14+o/ SsqHRE8s8kiGYh84D5kIloR2d3JWthR9+NPn0eQ+w6dmd+sPSk3aeSmKmNqCbQLwjmjC O/jA6Mhc9pQ42GYJvGsp1iQeBtXMe88vUy2EMYfcWVb0Ut+fLkvN/sPLnzNGOrbpUm3o 3NclJ1CirMlq438vCgYKZKTYteC027wgnRdiV/cQmM8wjgYPUQtL0q+1DKTwD3IyuJ8G fJI9Dly0dHiZaX//U6ShQj6XBsN/f42UPmDoVaCXwTnUinsCZITBM1laX2wzRZO4qdZE VKgw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=mpuQ+etJ3YDoMiQ6icPqBrPJtq1TTqUTa5MfYnpHeMA=; b=EhAUjypYjWt2x4tc/RoDhGOtugLHm3+TCxx9AP1v5MIRPGOZjD+OprOvfidVoc43ZA S2yqzRb9NXmpiHsvsw/1jsIt0HSkzqT3eoMJOfECDO0+4qiOLGxGW4WLPkPmp7Jn6lwt ixIugKI9jyrvqbF/zEhcRqPTZrLVKh7puxk7jmxJ2Ol6hB6854kTnFxvWuTL0xUYZerl my82ade5asRbt574MSBw1qojdVY/LCVJLQ7wvEZTsvwbHmA1MQLPe8Qwmgy6qVpQLT2j g+pakR4dP3ahsMx+V6zDr8glNzo5PyKl5lpdiee6m/Z4ge7vSxe4oRtU3NXiz1oVPTO9 //GA== 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 13si76211ejz.228.2020.06.03.09.53.53; Wed, 03 Jun 2020 09:54:17 -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 S1726173AbgFCQwH (ORCPT + 99 others); Wed, 3 Jun 2020 12:52:07 -0400 Received: from foss.arm.com ([217.140.110.172]:35692 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725961AbgFCQwH (ORCPT ); Wed, 3 Jun 2020 12:52:07 -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 20F3A31B; Wed, 3 Jun 2020 09:52:06 -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 6A6C83F305; Wed, 3 Jun 2020 09:52:03 -0700 (PDT) Date: Wed, 3 Jun 2020 17:52:00 +0100 From: Qais Yousef To: Vincent Guittot Cc: Mel Gorman , Patrick Bellasi , Dietmar Eggemann , Peter Zijlstra , Ingo Molnar , Randy Dunlap , Jonathan Corbet , Juri Lelli , Steven Rostedt , Ben Segall , Luis Chamberlain , Kees Cook , Iurii Zaikin , Quentin Perret , Valentin Schneider , Pavan Kondeti , linux-doc@vger.kernel.org, linux-kernel , linux-fs Subject: Re: [PATCH 1/2] sched/uclamp: Add a new sysctl to control RT default boost value Message-ID: <20200603165200.v2ypeagziht7kxdw@e107158-lin.cambridge.arm.com> References: <20200511154053.7822-1-qais.yousef@arm.com> <20200528132327.GB706460@hirez.programming.kicks-ass.net> <20200528155800.yjrmx3hj72xreryh@e107158-lin.cambridge.arm.com> <20200528161112.GI2483@worktop.programming.kicks-ass.net> <20200529100806.GA3070@suse.de> <87v9k84knx.derkling@matbug.net> <20200603101022.GG3070@suse.de> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: User-Agent: NeoMutt/20171215 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 06/03/20 16:59, Vincent Guittot wrote: > When I want to stress the fast path i usually use "perf bench sched pipe -T " > The tip/sched/core on my arm octo core gives the following results for > 20 iterations of perf bench sched pipe -T -l 50000 > > all uclamp config disabled 50035.4(+/- 0.334%) > all uclamp config enabled 48749.8(+/- 0.339%) -2.64% > > It's quite easy to reproduce and probably easier to study the impact Thanks Vincent. This is very useful! I could reproduce that on my Juno. One of the codepath I was suspecting seems to affect it. diff --git a/kernel/sched/core.c b/kernel/sched/core.c index 0464569f26a7..9f48090eb926 100644 --- a/kernel/sched/core.c +++ b/kernel/sched/core.c @@ -1063,10 +1063,12 @@ static inline void uclamp_rq_dec_id(struct rq *rq, struct task_struct *p, * e.g. due to future modification, warn and fixup the expected value. */ SCHED_WARN_ON(bucket->value > rq_clamp); +#if 0 if (bucket->value >= rq_clamp) { bkt_clamp = uclamp_rq_max_value(rq, clamp_id, uc_se->value); WRITE_ONCE(uc_rq->value, bkt_clamp); } +#endif } static inline void uclamp_rq_inc(struct rq *rq, struct task_struct *p) uclamp_rq_max_value() could be expensive as it loops over all buckets. Commenting this whole path out strangely doesn't just 'fix' it, but produces better results to no-uclamp kernel :-/ # ./perf bench -r 20 sched pipe -T -l 50000 Without uclamp: 5039 With uclamp: 4832 With uclamp+patch: 5729 It might be because schedutil gets biased differently by uclamp..? If I move to performance governor these numbers almost double. I don't know. But this promoted me to look closer and I think I spotted a bug where in the if condition we check for '>=' instead of '>', causing us to take the supposedly impossible fail safe path. Mind trying with the below patch please? diff --git a/kernel/sched/core.c b/kernel/sched/core.c index 0464569f26a7..50d66d4016ff 100644 --- a/kernel/sched/core.c +++ b/kernel/sched/core.c @@ -1063,7 +1063,7 @@ static inline void uclamp_rq_dec_id(struct rq *rq, struct task_struct *p, * e.g. due to future modification, warn and fixup the expected value. */ SCHED_WARN_ON(bucket->value > rq_clamp); - if (bucket->value >= rq_clamp) { + if (bucket->value > rq_clamp) { bkt_clamp = uclamp_rq_max_value(rq, clamp_id, uc_se->value); WRITE_ONCE(uc_rq->value, bkt_clamp); } Thanks -- Qais Yousef