Received: by 2002:a05:6358:45e:b0:b5:b6eb:e1f9 with SMTP id 30csp1656407rwe; Fri, 2 Sep 2022 01:11:31 -0700 (PDT) X-Google-Smtp-Source: AA6agR7OBLJl2vGAgYsUP1NDWz8k/aaMFF9+p4Gd+tZFr9dwCsiGjlrGM5Pu/6X9wDIpx/pYnJx4 X-Received: by 2002:a17:907:7f26:b0:74f:94f3:f92 with SMTP id qf38-20020a1709077f2600b0074f94f30f92mr1660108ejc.573.1662106291294; Fri, 02 Sep 2022 01:11:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1662106291; cv=none; d=google.com; s=arc-20160816; b=FghjZAe1i8Kh1oyknNEBdzY8F8oA80NVUBGRGNFK/WElQ7esLoTe9tD+iIBsoSAjyS LDw5Z7mVI0yymyeMyoNvh18bXJhtp4PlKGaiGlFKqMBxJnHjjjzuiGKhS+q1z+ZEveAe t1w7LNgShyOymUSV54i1mD0CUQJ0sj4rrX8jR259jm9SFQ9uG5PIuZSREuzs18GHlE6a yjs9n8qC4F8plAuJfkZTba3j5wAjt7Ju8zhXgVrxK1U5vriUbImKll4KgXLr35PLvuoQ 2r1OoOoX5AnEwgmWshwqoE5eYhlpWqcisceO1jXcwPKRHJ4hRGKn7aPH9NXcauum8RB8 7rLw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=sHsQOAo1CVK0wtIiF6im0whwHFnNWo5mTgCtjX4c6/U=; b=im85RyIX8uvgkAdZ8CG08G3eZfAno33Vw1AChl5YkuPR4Y1GDfLBuJk6ZjTtYMYGC8 mjNRDIiQSPLC76BwzFC3rrAPc9Csb/Nnpc7SXSfVw4fnPRaQl2FnbATfFfcIwuRGNxws mEppUr8sdfvJ5u/zsq6mBfs5lY7ysvzOsGhCtJ/mkFnsR65RNgMR2xFBj965U4m22FxU iVr4OP+BJrP1arAO7MnEFFBJD5FUfnc2npUAsdNJYXnNVcfea3nCy5obWbKAXO6UuymY V7a77/KiKq/VUi9IvJQtQ7E9mKUnsfyxhsNCXja1MBS9lCjoAr+zsva3qxnItg18VKOe dVrQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id mp16-20020a1709071b1000b0073832e13344si1485773ejc.86.2022.09.02.01.11.05; Fri, 02 Sep 2022 01:11:31 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233014AbiIBHxn (ORCPT + 99 others); Fri, 2 Sep 2022 03:53:43 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42520 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235271AbiIBHxi (ORCPT ); Fri, 2 Sep 2022 03:53:38 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 58296B5A4E for ; Fri, 2 Sep 2022 00:53:37 -0700 (PDT) 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 1411DD6E; Fri, 2 Sep 2022 00:53:43 -0700 (PDT) Received: from [192.168.1.162] (unknown [172.31.20.19]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id B7EB23F766; Fri, 2 Sep 2022 00:53:34 -0700 (PDT) Message-ID: <6281126b-3b93-86fa-25d6-d637b6c7dd87@arm.com> Date: Fri, 2 Sep 2022 09:53:22 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.9.1 Subject: Re: [RFC PATCH 1/1] sched/pelt: Introduce PELT multiplier Content-Language: en-US To: Peter Zijlstra Cc: Ingo Molnar , Vincent Guittot , Morten Rasmussen , Vincent Donnefort , Quentin Perret , Patrick Bellasi , Abhijeet Dharmapurikar , Jian-Min , Qais Yousef , linux-kernel@vger.kernel.org References: <20220829055450.1703092-1-dietmar.eggemann@arm.com> <20220829055450.1703092-2-dietmar.eggemann@arm.com> From: Dietmar Eggemann In-Reply-To: Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-6.9 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_HI,SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 29/08/2022 12:02, Peter Zijlstra wrote: > On Mon, Aug 29, 2022 at 10:08:13AM +0200, Peter Zijlstra wrote: >> On Mon, Aug 29, 2022 at 07:54:50AM +0200, Dietmar Eggemann wrote: >>> From: Vincent Donnefort [...] >>> +extern unsigned int sched_pelt_lshift; >>> + >>> +/* >>> + * absolute time |1 |2 |3 |4 |5 |6 | >>> + * @ mult = 1 --------****************--------****************- >>> + * @ mult = 2 --------********----------------********--------- >>> + * @ mult = 4 --------****--------------------****------------- >>> + * clock task mult >>> + * @ mult = 2 | | |2 |3 | | | | |5 |6 | | | >>> + * @ mult = 4 | | | | |2|3| | | | | | | | | | |5|6| | | | | | | >>> + * >>> + */ >>> +static inline void update_rq_clock_task_mult(struct rq *rq, s64 delta) >>> +{ >>> + delta <<= READ_ONCE(sched_pelt_lshift); >>> + >>> + rq->clock_task_mult += delta; >>> + >>> + update_rq_clock_pelt(rq, delta); >>> +} >> >> Hurmph... I'd almost go write you something like >> static_call()/static_branch() but for immediates. >> >> That said; given there's only like 3 options, perhaps a few >> static_branch() instances work just fine ? > > Also, I'm not at all sure about exposing that as an official sysctl. > > How about something like so? [...] > void update_rq_clock(struct rq *rq) > --- a/kernel/sched/features.h > +++ b/kernel/sched/features.h > @@ -101,3 +101,6 @@ SCHED_FEAT(LATENCY_WARN, false) > > SCHED_FEAT(ALT_PERIOD, true) > SCHED_FEAT(BASE_SLICE, true) > + > +SCHED_FEAT(PELT_M2, false) > +SCHED_FEAT(PELT_M4, false) The sched features interface would definitely be much less official but I think it's not useful for Android since they don't mount debugfs anymore. [...]