Received: by 2002:a5d:925a:0:0:0:0:0 with SMTP id e26csp1291947iol; Fri, 10 Jun 2022 04:37:51 -0700 (PDT) X-Google-Smtp-Source: ABdhPJySnzfRTngLEHnyzjdU7/B9Jc+EEe7NJCM0ejvgGzPjcGutvLId7UKLAyP8Gfpa/mEc4my9 X-Received: by 2002:a17:906:7944:b0:6da:b834:2f3e with SMTP id l4-20020a170906794400b006dab8342f3emr41526168ejo.353.1654861071590; Fri, 10 Jun 2022 04:37:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1654861071; cv=none; d=google.com; s=arc-20160816; b=ZoD8OuKWbI8BzJV5rzV+//0Gpv6D9VLSueCL4IgdMn/vj2TkcSrbNoeDa1PtvnSQAa lNwaD3cTUgdTuctzassBXj46n76FUnpwq3RdwCvr808qm6d9OEtQCxEEI8YP8gjTpb6t 61gX4PvxrXWbSBQtNGpNLWuRGHrSPTo5DxFJQgzhxBXsqjnVMnJ5BcJqDWncC626HEpM 6TehBh35vg3Zn9qp0vqjgAlbJZ8zdLqF2OidbjkVz6Y9TvKvPOajuXUXDeAL1uiC9Qsd kervde98vEmkNIkCpqdB+nhZd29WZgNflRjoXbdesdzrUep2iFnFM8ujOCW4N7lSOuoM 3/lA== 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=BtWny38+4+FL83thBV8vCGmj+uN9P6mtvQSzNk5aMcA=; b=Rj+xJlEBm8Eymi0nsOvemuxQ3CU6Zb4IlCgDPHopv8JrBmjkv6ReQ/XydIVIkTvs+H yZClyorAItVuGf5r58Khh1wGoZSdT4n+kmFIadwpeEXpv2wyWyEdhw0KAvh3fEL7pN0M B0w5qjA1tDAr8xjwa5OE1cz0DcRRNZ/lXnEwRMQJE3dFcd2aih+7vMfux7q5AtPDB2WM U0V/AgVpCKnEQ0LTOT3dO75rMeYcVgVrIFAvAPyJcW7//oR0zVRTtw950ssFVVun//cd gKE8+h9laERWxGEH3dhl+2bNzU9sp6IKeo+31MB6Mn5+D/7ptopXnZ5BVQQQO9bn0VGb VvGA== 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 s14-20020a056402520e00b0042e15364b0fsi29015377edd.273.2022.06.10.04.37.26; Fri, 10 Jun 2022 04:37:51 -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 S1348996AbiFJKxT (ORCPT + 99 others); Fri, 10 Jun 2022 06:53:19 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59634 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1348875AbiFJKxA (ORCPT ); Fri, 10 Jun 2022 06:53:00 -0400 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 209F7313349 for ; Fri, 10 Jun 2022 03:49:31 -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 DA99D12FC; Fri, 10 Jun 2022 03:49:30 -0700 (PDT) Received: from [10.5.48.228] (unknown [172.31.20.19]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 3E0023F766; Fri, 10 Jun 2022 03:49:26 -0700 (PDT) Message-ID: <67c7e9ea-1d3b-39f0-c1b6-4940ed45844d@arm.com> Date: Fri, 10 Jun 2022 12:49:00 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.8.1 Subject: Re: [PATCH v2] sched/fair: combine detach into dequeue when migrating task Content-Language: en-US To: Chengming Zhou , mingo@redhat.com, peterz@infradead.org, juri.lelli@redhat.com, vincent.guittot@linaro.org, rostedt@goodmis.org, bsegall@google.com, mgorman@suse.de, bristot@redhat.com, vschneid@redhat.com Cc: linux-kernel@vger.kernel.org, duanxiongchun@bytedance.com, songmuchun@bytedance.com References: <20220609035326.91544-1-zhouchengming@bytedance.com> From: Dietmar Eggemann In-Reply-To: <20220609035326.91544-1-zhouchengming@bytedance.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-8.1 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 09/06/2022 05:53, Chengming Zhou wrote: > When we are migrating task out of the CPU, we can combine detach > into dequeue_entity() to save the independent detach_entity_cfs_rq() > in migrate_task_rq_fair(). > > This optimization is like combining DO_ATTACH in the enqueue_entity() > when migrating task to the CPU. > > So we don't have to traverse the CFS tree twice to do these load > detach and propagation. By `propagation` you refer to the detach_entity_cfs_rq() -> propagate_entity_cfs_rq() call? This one wouldn't be called anymore with your change. [...] > @@ -4426,6 +4435,14 @@ static __always_inline void return_cfs_rq_runtime(struct cfs_rq *cfs_rq); > static void > dequeue_entity(struct cfs_rq *cfs_rq, struct sched_entity *se, int flags) > { > + int action = UPDATE_TG; > + > + /* > + * If we are migrating task from the CPU, detach load_avg when dequeue. > + */ > + if (entity_is_task(se) && task_of(se)->on_rq == TASK_ON_RQ_MIGRATING) - if (entity_is_task(se) && task_of(se)->on_rq == TASK_ON_RQ_MIGRATING) + if (entity_is_task(se) && task_on_rq_migrating(task_of(se))) > + action |= DO_DETACH; With the `entity_is_task(se)` you make sure we only call detach_entity_load_avg() and update_tg_load_avg() for the se representing the task itself (and not taskgroups the task might run in). So IMHO this looks good. You save the propagate_entity_cfs_rq(&p->se) call from (2) by doing the detach_entity_load_avg(), update_tg_load_avg() for a migrating task inside (1) (the task being the first se in the loop ) detach_task() deactivate_task() dequeue_task_fair() for_each_sched_entity(se) dequeue_entity() update_load_avg() /* (1) */ set_task_cpu() migrate_task_rq_fair() /* called detach_entity_cfs_rq() before the patch (2) */ [...] > @@ -6940,15 +6957,10 @@ static void migrate_task_rq_fair(struct task_struct *p, int new_cpu) > se->vruntime -= min_vruntime; > } > > - if (p->on_rq == TASK_ON_RQ_MIGRATING) { > - /* > - * In case of TASK_ON_RQ_MIGRATING we in fact hold the 'old' > - * rq->lock and can modify state directly. > - */ > - lockdep_assert_rq_held(task_rq(p)); > - detach_entity_cfs_rq(&p->se); > - > - } else { > + /* > + * In case of TASK_ON_RQ_MIGRATING we already detach in dequeue_entity. > + */ > + if (p->on_rq != TASK_ON_RQ_MIGRATING) { - if (p->on_rq != TASK_ON_RQ_MIGRATING) { + if (!task_on_rq_migrating(p)) { [...]