Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp2237684imm; Tue, 10 Jul 2018 16:10:08 -0700 (PDT) X-Google-Smtp-Source: AAOMgpfgNv7JGHOCJaUqUjZfIO24P74PRQI2Rp97YQ+SdXCv+zQ3K1TqVrzLWwYrRkh5BM3xY7dr X-Received: by 2002:a62:2983:: with SMTP id p125-v6mr13520481pfp.128.1531264208149; Tue, 10 Jul 2018 16:10:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1531264208; cv=none; d=google.com; s=arc-20160816; b=dLh17tV7wtthI1Ap19hWog8+MKrU43h9zpWz7Lxbr/onX75Y4k/JXg8KX5Aq00bPme 15ETgcE2u7NDihoDiQlYCd6qiGEhFO9W8BL9RN1bJDSnm33KJp87itQs6xQ9aNCzZeXQ o2geQk7g2OyGwcstvHccpOwQ6M4CbN5+SLMcT/i9VHnCU30rHX3tprEld1LBI5/AkblP HszQ7cGiWteASlVvilC+LtqCq29BKQiGFutQbhFTEsb8PRi2tvYb04uh/vC/Pjaoo12c mFq4zjNp/coWyhr3tCKYFEdq2w6SQhk2PgVDIvdoW+tXad7riQdXNRaCGZaPpXne0j+v ts3Q== 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:dkim-signature:arc-authentication-results; bh=bCrVqF/4xU/NZolCM6FpF6mkmZ+l7CQSJ+ObQfuSAes=; b=YF/gO2DjKTouCru0v0aRMuacROnnMAYdNfnNx6EAW4c8JyCueQcXA70szLtfauHkdL kuBxq7c4j91UefeZHQeOi3yRl+NJN5Mu/tOSGWcuh68+gB4tVnoL5ONH3/QF56/88/W4 RGIga+y7JxTp9kbeOxQVKAGu4QLyjYXDyIXVZ0qniiWHXbZ8zZu62fCMcoyhW5fWIwjw 04FWQmO6FSwc/O9HxZhZprXc2/5G6i+M96Feqhh6+KBbl9DnPOPOeQmWeoEJhT4H1+Y6 HP9JnLcmTBVjFsE9TWN0+RMu8MhEYUlzrWRFwgz2HfZy37laS7CtemrpH8+zKLTi8kdf Tfow== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@joelfernandes.org header.s=google header.b=vkQ3934O; 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 d4-v6si18070233pfa.263.2018.07.10.16.09.52; Tue, 10 Jul 2018 16:10:08 -0700 (PDT) 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; dkim=pass header.i=@joelfernandes.org header.s=google header.b=vkQ3934O; 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 S1732365AbeGJXKi (ORCPT + 99 others); Tue, 10 Jul 2018 19:10:38 -0400 Received: from mail-pl0-f68.google.com ([209.85.160.68]:45939 "EHLO mail-pl0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732253AbeGJXKh (ORCPT ); Tue, 10 Jul 2018 19:10:37 -0400 Received: by mail-pl0-f68.google.com with SMTP id a17-v6so2428302plm.12 for ; Tue, 10 Jul 2018 16:09:18 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=joelfernandes.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=bCrVqF/4xU/NZolCM6FpF6mkmZ+l7CQSJ+ObQfuSAes=; b=vkQ3934OTtHCizpX8Ka9zlT0hsj3rXv7V5pQiGmZBPQGU34z9dqVdpm5sMqHYh5JMo FE5vbLInKXpS4zCgyDF9Xay4H/u+pyleVgiFQ935Kd4BjaWkNip//K7EYeM6TQAm/2xG 9NNDtJykK/hbsOIy8XH1edtz4OMEaJszxYOiU= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=bCrVqF/4xU/NZolCM6FpF6mkmZ+l7CQSJ+ObQfuSAes=; b=bCvs6VFZ0ihYZCHHgLnYTbPX1sDw4Yzbtem2lIBld+8iRbyU0FTyLjKYqcAZ1thA7w VTgqXU1MQnuu2BR47I3tewPC/H/8nlbELyl7L4QD9/74FdOCsXYzr+Tf+ZxxPq+pig81 Bh/yyvonZiAOzxKD4QzLCJ9qXIf7rRPKSfZ9jA9ClLBEs7LfdZsC4bEk6t47qX/P/fiP AG6wAqdclvsT3uM2rvb/8fTssof/jebCEKQvAqqwEHWMZXJYTcj22cy/7GY53nq6Nigo AYGn0XT9SrC0Z7l/qcy/DFk2V8zOKdPLibIaLAl+Rk+i0fJ1LrgJFXe2lyD4vysHzilB bYrQ== X-Gm-Message-State: APt69E3R0Z1EvlL+Bvq0+0Etzfyjwk4Bnc2CRhFHwN1w1A0/vZ1cxZ7K L2jFaKZ3dDb196jRbYgykjhB7A== X-Received: by 2002:a17:902:b586:: with SMTP id a6-v6mr26304962pls.174.1531264158169; Tue, 10 Jul 2018 16:09:18 -0700 (PDT) Received: from localhost ([2620:0:1000:1600:3122:ea9c:d178:eb]) by smtp.gmail.com with ESMTPSA id p62-v6sm29406089pfb.58.2018.07.10.16.09.17 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Tue, 10 Jul 2018 16:09:17 -0700 (PDT) Date: Tue, 10 Jul 2018 16:09:17 -0700 From: Joel Fernandes To: Dietmar Eggemann Cc: Peter Zijlstra , Ingo Molnar , Vincent Guittot , Morten Rasmussen , Patrick Bellasi , Quentin Perret , kernel-team@android.com, Joel Fernandes , linux-kernel@vger.kernel.org Subject: Re: [PATCH] sched/fair: Remove setting task's se->runnable_weight during PELT update Message-ID: <20180710230917.GA187293@joelaf.mtv.corp.google.com> References: <20180709164753.24699-1-dietmar.eggemann@arm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180709164753.24699-1-dietmar.eggemann@arm.com> User-Agent: Mutt/1.9.2 (2017-12-15) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Jul 09, 2018 at 05:47:53PM +0100, Dietmar Eggemann wrote: > A CFS (SCHED_OTHER, SCHED_BATCH or SCHED_IDLE policy) task's > se->runnable_weight must always be in sync with its se->load.weight. > > se->runnable_weight is set to se->load.weight when the task is > forked (init_entity_runnable_average()) or reniced (reweight_entity()). > > There are two cases in set_load_weight() which since they currently only > set se->load.weight could lead to a situation in which se->load.weight > is different to se->runnable_weight for a CFS task: > > (1) A task switches to SCHED_IDLE. > > (2) A SCHED_FIFO, SCHED_RR or SCHED_DEADLINE task which has been reniced > (during which only its static priority gets set) switches to > SCHED_OTHER or SCHED_BATCH. > > Set se->runnable_weight to se->load.weight in these two cases to prevent > this. This eliminates the need to explicitly set it to se->load.weight > during PELT updates in the CFS scheduler fastpath. Looks good to me. By the way just asking, is there a chance where se_weight(se) and se_runnable(se) can ever be different? Seems not, then in that case we pointlessly do this division in ___update_load_avg if the sa belongs to the task: sa->load_avg = div_u64(load * sa->load_sum, divider); sa->runnable_load_avg = div_u64(runnable * sa->runnable_load_sum, divider); and we could probably just do this if se is a task? sa->load_avg = div_u64(load * sa->load_sum, divider); sa->runnable_load_avg = sa->load_avg; thanks, -Joel