Received: by 2002:a05:6a10:a0d1:0:0:0:0 with SMTP id j17csp1547374pxa; Thu, 6 Aug 2020 10:00:37 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw6N7XZ0xCG7+wJsvi7NlpWfQr/IhoxbHVxmwXnGjRp8mwlGJlbyJrTrDhdrH3j17hkbxJ8 X-Received: by 2002:a17:906:b2d0:: with SMTP id cf16mr5212042ejb.476.1596733237787; Thu, 06 Aug 2020 10:00:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1596733237; cv=none; d=google.com; s=arc-20160816; b=V1OaRozzZ4bSYo2tB9+Q4qOvmv8FV/wOnaH1Mr9mfgqoEK2MYsi7Wnk6Oay4SX//na pwXE0kkhemQpbpqckzAWW6krWO2+h3F8vBHO/E1YbOv2bS4eJt2fjKCDkraC+uQsvsdN 2FqV+7Wn/csv1vq5Wuf0o8ml3gq0qlqfmh7n2NlDt6s6/2rBXfIpBsM/WtbfHBnmugG/ f01gdy5EXXENW8Ni8t/sfQLQX94h/RKoTlo1jueew4DoFtVf+Tj3Oo+uXrXbH8HuQRJ/ +EqbilNTyry+lvjVH3u+psv/x9OTf51x3c6ooWS7h01z2yE+CSkhEUkY8l7yBUo0fIMw MdZg== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=E+VfmnxDV498yxI5rDUMFgAbVpKeY5DLzESFio3gnB4=; b=l+UwbV8belbO8WA2lasWv1Z57B96eI7G+0i8Ni+ywXaVuTaSQdQC47vVMedD/qqOSv Nut+GWNVHrkTIrwB/ZcR6JyDuYRFw65DVxHpTS19aRLGDn8/yQ1CFoZMWlsW9jgLEywg UNyfQK2HRmBytEYJpCSz4hIBVJ7fxjYDepakOGU7Dxu29A/dmBuK1+84n6F5irIkyyTu BfiiqJPxim9U+OmvVNRJCGgOl44GDak17WifMvqgptpPYvb7oPO7p3hQSYZWhku5oLHz tU2Fndd0ATLJnRZmuve3HRcQgvIIX3/SDtSEIwb0guMEr++3TEExHCsUO7v9muiugMND Tmdg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=UBJ+xRcZ; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id e17si4130013edc.382.2020.08.06.10.00.15; Thu, 06 Aug 2020 10:00: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=@gmail.com header.s=20161025 header.b=UBJ+xRcZ; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728840AbgHFQ7y (ORCPT + 99 others); Thu, 6 Aug 2020 12:59:54 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:41644 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728999AbgHFQkk (ORCPT ); Thu, 6 Aug 2020 12:40:40 -0400 Received: from mail-pl1-x642.google.com (mail-pl1-x642.google.com [IPv6:2607:f8b0:4864:20::642]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 21CA1C002174 for ; Thu, 6 Aug 2020 09:14:46 -0700 (PDT) Received: by mail-pl1-x642.google.com with SMTP id r4so17213173pls.2 for ; Thu, 06 Aug 2020 09:14:46 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=E+VfmnxDV498yxI5rDUMFgAbVpKeY5DLzESFio3gnB4=; b=UBJ+xRcZblEVxSJwz/PK+6Kw1nyvUVkSJPh5W3yJfyKUV1zBsLoDfTSVMzPYi0aXAB MoIYnymHlZyzMpW2QDQGcE1yacW3lPSxo41W77F74qUi7yZyaUPg4mZaaTps4uw7arDv MHSZarQlh9DmRRObpE31wn60GWelGoIPB5AylEpEXUq4SI+QeMWpN/xCPgXX1c1h//Sp S9Ey6QXTSzW1azNC4LSOgHLG0DM60r0TB8IOANE/aQ4gxx5NyI3mz9gnPTAW/h9jxKfp 0lb+PuigzZbdX2MQNlrcwr4HG7qc6BD+BJ/i/5L79G1rwr7l4ZDWOMuBD7XJZmcLs1MT o4KA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=E+VfmnxDV498yxI5rDUMFgAbVpKeY5DLzESFio3gnB4=; b=SBwnrenk2TlLHmHqwQdZ9N44NQ2mS85L2DpxBwFRZB77ilnNExoP+VEYN5J0M1Z2Zv +tM2ip3ZuFA4zWqku8hsner9i/80LJKBNpqUhDSsFpNVqwpKkyCSfWJvvGzwwU9T0z5e w4RU33xki2cxtZ83xstkPxC0D4fU/LSKwSc8n/MpiDzC6tBCBRIlE4VOzntu002vdTH2 Vn6fcBiMpNxzZZw1BLmlztYeuLXS7BO+wRmRY5WQzDWySNIioB5NnDbzEj7QywLLe67U zg5qoR4RQcrNxXGyw5dxVgg/uLBeuZyioq+GldYdAibwPGOaZxiH9LRtixa+GEM5SItq A6EA== X-Gm-Message-State: AOAM5330OeXPq5ZwXtTN/XtgBhYo1U8WMQL1s1C0mN6jD1O7ef20Sfdn 9dikICr73SKkc45BxIif9oA= X-Received: by 2002:a17:90a:e551:: with SMTP id ei17mr9109006pjb.224.1596730485648; Thu, 06 Aug 2020 09:14:45 -0700 (PDT) Received: from localhost.localdomain ([112.44.78.113]) by smtp.gmail.com with ESMTPSA id x127sm9537245pfd.86.2020.08.06.09.14.39 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Thu, 06 Aug 2020 09:14:44 -0700 (PDT) From: Jiang Biao X-Google-Original-From: Jiang Biao To: mingo@redhat.com, peterz@infradead.org, juri.lelli@redhat.com, vincent.guittot@linaro.org Cc: dietmar.eggemann@arm.com, rostedt@goodmis.org, bsegall@google.com, mgorman@suse.de, linux-kernel@vger.kernel.org, Jiang Biao Subject: [PATCH RFC v2] sched/fair: simplify the work when reweighting entity Date: Fri, 7 Aug 2020 00:14:06 +0800 Message-Id: <20200806161406.22629-1-benbjiang@tencent.com> X-Mailer: git-send-email 2.21.0 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Jiang Biao If a se is on_rq when reweighting entity, all we need should be updating the load of cfs_rq, other dequeue/enqueue work could be redundant, such as, * nr_running--/nr_running++ Even though the following dequeue/enqueue path would never be reached * account_numa_dequeue/account_numa_enqueue * list_del/list_add from/into cfs_tasks but it could be a little confusing. Simplifying the logic could be helpful to reduce a litte overhead for hot path, and make it cleaner and more readable. Signed-off-by: Jiang Biao --- v2<-v1: - Amend the commit log. kernel/sched/fair.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c index 04fa8dbcfa4d..18a8fc7bd0de 100644 --- a/kernel/sched/fair.c +++ b/kernel/sched/fair.c @@ -3086,7 +3086,7 @@ static void reweight_entity(struct cfs_rq *cfs_rq, struct sched_entity *se, /* commit outstanding execution time */ if (cfs_rq->curr == se) update_curr(cfs_rq); - account_entity_dequeue(cfs_rq, se); + update_load_sub(&cfs_rq->load, se->load.weight); } dequeue_load_avg(cfs_rq, se); @@ -3102,7 +3102,7 @@ static void reweight_entity(struct cfs_rq *cfs_rq, struct sched_entity *se, enqueue_load_avg(cfs_rq, se); if (se->on_rq) - account_entity_enqueue(cfs_rq, se); + update_load_add(&cfs_rq->load, se->load.weight); } -- 2.21.0