Received: by 2002:a05:7412:8d10:b0:f3:1519:9f41 with SMTP id bj16csp5168769rdb; Wed, 13 Dec 2023 00:19:51 -0800 (PST) X-Google-Smtp-Source: AGHT+IGEwgO1BeDiljJeltNo3y6l2BsI5gKFeENf5/kTr0aTM4wIC+LaSN78Alt5X44TILhov/Ev X-Received: by 2002:a17:902:e5cd:b0:1cf:cd31:6b85 with SMTP id u13-20020a170902e5cd00b001cfcd316b85mr7937527plf.27.1702455591079; Wed, 13 Dec 2023 00:19:51 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1702455591; cv=none; d=google.com; s=arc-20160816; b=CJx1oVo8kJ47bwgWHaX80aeFGfzl+K/mrSflkm7yRW3EP5bcyverIL+Gtli6UPKfYz 8QytAosYT/HazxIF8CM7h1NNMthF93cJPSOcYK7WOI4lEPGL3jR0XyBIF0RCn6DozkPf O04mdw0J5ITW1cqt0YiQ9N9Q4guh7C0n46gudwDHP1tIVCelaMWgy+GGHmtTmX1iOMaH HHZ+qOfpiIXFV9tTcY39SIkl5Y/yE1qIJC3uGP5jOnSnZ5GL5Dyc3772S5Z+BkUEj8uU QqBvfUCV0djszMD7Aw//3F71GXsScpwH7R0Xz9PS8GYVUQgbRPO21tL11ELXv7LgYy1D bdvg== 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:dkim-signature; bh=lFigjVu5W6ScDqNFv0bLuZxvlmLPor2lw0m8dW0Y2WM=; fh=WLhd+93rWsvU6wdOfwU+fP2yylmedUR3XSK/SxFQhzM=; b=BrpWkVmykeIHaKpHtYmAjrOe5+fe1jgB7UqYZGVguKBmojKsd0hTA64pkQwTqo4b9s SJtd9V0VUYexVmEOPc6CRhVoT/TbV5yRSlvreCH8pYgaJLT8eSn02PleqdyQZzH9zDeN 1TwVDJaJSXgVhU5idaqyLGQ3yvyRRaoDlBUhI/Z3o9EALYuNPkttEk5ah6foGeNCwinn KTBHMqyri+2V+wg3NaY7+NkpcY98pj6WWul2FlQksto90pTKxcdhIPNtpwEXfj3pZ2pF QvIfatuim6t9/fcXELonLuJ9gusMPkGm/WDPWUpZ2obOhOpAW4C6JOvFPzuKSKX0I3Ym 56ng== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bytedance.com header.s=google header.b=hTgBXA1N; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:2 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=bytedance.com Return-Path: Received: from agentk.vger.email (agentk.vger.email. [2620:137:e000::3:2]) by mx.google.com with ESMTPS id u15-20020a17090341cf00b001cfc9894958si9663043ple.379.2023.12.13.00.19.50 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 13 Dec 2023 00:19:51 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:2 as permitted sender) client-ip=2620:137:e000::3:2; Authentication-Results: mx.google.com; dkim=pass header.i=@bytedance.com header.s=google header.b=hTgBXA1N; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:2 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=bytedance.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by agentk.vger.email (Postfix) with ESMTP id 61416807C656; Wed, 13 Dec 2023 00:19:48 -0800 (PST) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.11 at agentk.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230029AbjLMIT0 (ORCPT + 99 others); Wed, 13 Dec 2023 03:19:26 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34420 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229637AbjLMITZ (ORCPT ); Wed, 13 Dec 2023 03:19:25 -0500 Received: from mail-pg1-x52f.google.com (mail-pg1-x52f.google.com [IPv6:2607:f8b0:4864:20::52f]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 886058E for ; Wed, 13 Dec 2023 00:19:09 -0800 (PST) Received: by mail-pg1-x52f.google.com with SMTP id 41be03b00d2f7-5ca29c131ebso1992712a12.0 for ; Wed, 13 Dec 2023 00:19:09 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bytedance.com; s=google; t=1702455549; x=1703060349; darn=vger.kernel.org; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :from:to:cc:subject:date:message-id:reply-to; bh=lFigjVu5W6ScDqNFv0bLuZxvlmLPor2lw0m8dW0Y2WM=; b=hTgBXA1N1Ih0sfBsTiRV7V96+fiUX1jOej4IRYzKF1uZeX1RHY+B5AOFZqMfRRAU2V 9BOS9YIVm+ACwO/lof2o3rQsuMei9EyiuxP9sEyT4SJVXrMyTjuzXgQIsWPlI45R2MS8 /dB1fvrqFt3mP0FY5i5CrdXzdDxvYjaygjGjHjow3PFz8lmlgtVi3CLtR8UJcgtpL2B4 R1LHT3l7hKyynise8U/9YeZjZTNtz6ZtNOehEXLkBRPX3rxCoRRK0f9yyT+qN38W5FSe Xz5GdlruGFTretO6TvzmN0QFup0pRHDEQB2JMWoXFTMZZ3ZV43vbHz+fXZZhPwRCkQtC BvCQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1702455549; x=1703060349; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=lFigjVu5W6ScDqNFv0bLuZxvlmLPor2lw0m8dW0Y2WM=; b=ooPj+pjA66fVsB2iEZ0pgCJc6N2lt9M0Wv8x3OM5l21rTiPbQB5jsvccWUTQOjmq9/ yjB1U5WGcDoYXug2+ry248VEe64VSjfm9Ec8xEqrIHCGooh+tvcUqbfUm6xXcLob5SIz KetNetDOXGQHOfZsvwblTtzjjrrlI8a1WnGYe+7xDEe3uk56qovVLwQ4IOZ05eH4xP9r dKnjlzWkD+ItfbN+w9Mv1b5glM79YjOdT+OqAo0VKaDZefC6ox7BBrYPdjzIRnFQkqoI 7X1L93VWwoA+Lwy/1kE6y773y+iRzFqZpwJ3qbgjY7lTTiuFkxl2W/0NH4tn5xeeOZ4M DBzg== X-Gm-Message-State: AOJu0Yx2KvDz9s0QFe/joCA54gAfEVI2TGHoaE4nRAXrLDKGl1Hldciv TSTt11Tqtb1+XvmQzkOF7wAgwg== X-Received: by 2002:a05:6a20:4f91:b0:18f:d275:9f33 with SMTP id gh17-20020a056a204f9100b0018fd2759f33mr7514739pzb.119.1702455549028; Wed, 13 Dec 2023 00:19:09 -0800 (PST) Received: from [10.84.154.56] ([203.208.167.146]) by smtp.gmail.com with ESMTPSA id r22-20020aa78456000000b006ce7c28be72sm2431727pfn.118.2023.12.13.00.18.58 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 13 Dec 2023 00:19:08 -0800 (PST) Message-ID: Date: Wed, 13 Dec 2023 16:18:55 +0800 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v2] sched/fair: merge same code in enqueue_task_fair Content-Language: en-US To: WangJinchao , Ingo Molnar , Peter Zijlstra , Juri Lelli , Vincent Guittot , Dietmar Eggemann , Steven Rostedt , Ben Segall , Mel Gorman , Daniel Bristot de Oliveira , Valentin Schneider , linux-kernel@vger.kernel.org Cc: stone.xulei@xfusion.com References: <202312131510+0800-wangjinchao@xfusion.com> From: Abel Wu In-Reply-To: <202312131510+0800-wangjinchao@xfusion.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on agentk.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (agentk.vger.email [0.0.0.0]); Wed, 13 Dec 2023 00:19:48 -0800 (PST) Hi Jinchao, On 12/13/23 3:12 PM, WangJinchao Wrote: > The code below is duplicated in two for loops and need to be > consolidated It doesn't need to, but it can actually bring some benefit from the point of view of text size, especially in warehouse-scale computers where icache is extremely contended. add/remove: 0/0 grow/shrink: 0/1 up/down: 0/-56 (-56) Function old new delta enqueue_task_fair 936 880 -56 Total: Before=64899, After=64843, chg -0.09% > > Signed-off-by: WangJinchao > --- > kernel/sched/fair.c | 31 ++++++++----------------------- > 1 file changed, 8 insertions(+), 23 deletions(-) > > diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c > index d7a3c63a2171..e1373bfd4f2e 100644 > --- a/kernel/sched/fair.c > +++ b/kernel/sched/fair.c > @@ -6681,30 +6681,15 @@ enqueue_task_fair(struct rq *rq, struct task_struct *p, int flags) > cpufreq_update_util(rq, SCHED_CPUFREQ_IOWAIT); > > for_each_sched_entity(se) { > - if (se->on_rq) > - break; > cfs_rq = cfs_rq_of(se); > - enqueue_entity(cfs_rq, se, flags); > - > - cfs_rq->h_nr_running++; > - cfs_rq->idle_h_nr_running += idle_h_nr_running; > - > - if (cfs_rq_is_idle(cfs_rq)) > - idle_h_nr_running = 1; > - > - /* end evaluation on encountering a throttled cfs_rq */ > - if (cfs_rq_throttled(cfs_rq)) > - goto enqueue_throttle; > - > - flags = ENQUEUE_WAKEUP; > - } > - > - for_each_sched_entity(se) { > - cfs_rq = cfs_rq_of(se); > - > - update_load_avg(cfs_rq, se, UPDATE_TG); > - se_update_runnable(se); > - update_cfs_group(se); > + if (se->on_rq) { > + update_load_avg(cfs_rq, se, UPDATE_TG); > + se_update_runnable(se); > + update_cfs_group(se); > + } else { > + enqueue_entity(cfs_rq, se, flags); > + flags = ENQUEUE_WAKEUP; > + } > > cfs_rq->h_nr_running++; > cfs_rq->idle_h_nr_running += idle_h_nr_running; I have no strong opinon about this 'cleanup', but the same pattern can also be found in dequeue_task_fair() and I think it would be better get them synchronized. Thanks, Abel