Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp2649403ybz; Mon, 27 Apr 2020 01:39:15 -0700 (PDT) X-Google-Smtp-Source: APiQypKaUnG5XyhCKQTtVX6CaOuxert0ct2XY33Rr9Y15ra05HFisyVrizKCSv5p2gZtSx3oeBDy X-Received: by 2002:a50:f390:: with SMTP id g16mr16943804edm.211.1587976755564; Mon, 27 Apr 2020 01:39:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587976755; cv=none; d=google.com; s=arc-20160816; b=fCAVa5G+XW1QafuP+plOlEzEtG6MguWFAaNoLGnwIrvmeDuELzcZPns3zURLUXxsU8 9g0bD00dq9mnoL90cUJzItZ1f6XgkqbtXUAz1tcysTL1an9bEM/ZBpsV2oafamgowGSZ 7V38GCog8CMaLY0+OWCO561BvcZE1MwtE8MO6jhRj0MU8h6BvCfQyBylOets6LtP07VY Zc/FQtgH5Fv/NpYlNOKaR8DBS/0jJ/WqQ8MPnN/vBxfsALeLUFz84eWfu8mYnk+0pIOl GnvRdtrsdqp4/pG0nWSGcrFYxqiUOQcDWNInuDynLy5bB1rbVepuVYGazOGfJfPCkI7U QKJQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=1kpljo0aOwkRrM1iHyRsVe88uZbc6jsb6qp8kpcsxnk=; b=MPfL21WFTfxm2dVLFqZXpKd+RqU2+Lolz4HZuomcVikQaZSmyaM/4jOfFUwMF1x0Rt 62LIlcWFDEETzZ5dzpBOzsc20dL9DlbNr9wmhe4egJT1JlLHmCGCasbfQkCJtk6tFyS2 NCM1gFKQuVOhrQLOOcbWiubfP1cBfnvAXiUQpMIWPjaUjsYKE+lxYIEA/834WD9ndRvr ENRG1S4SD+8lUH9t7hM/MJg1D6C9C9LTp4EQVE5/oZp1cs9g6Fvh6FJL69yMm+VMj+I8 HYQeqIqWm9avAtU3k8MeAQeQvYBOLZ0940qQtQCAPqXlClegeQnjB4hMtQqVkjQImq3d wntQ== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id cm18si7254213edb.130.2020.04.27.01.38.52; Mon, 27 Apr 2020 01:39:15 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726700AbgD0Ihc (ORCPT + 99 others); Mon, 27 Apr 2020 04:37:32 -0400 Received: from foss.arm.com ([217.140.110.172]:59856 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725899AbgD0Ihc (ORCPT ); Mon, 27 Apr 2020 04:37:32 -0400 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 29A871FB; Mon, 27 Apr 2020 01:37:31 -0700 (PDT) Received: from dell3630.arm.com (unknown [172.31.20.19]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id 4AD333F68F; Mon, 27 Apr 2020 01:37:27 -0700 (PDT) From: Dietmar Eggemann To: Ingo Molnar , Peter Zijlstra , Juri Lelli Cc: Vincent Guittot , Steven Rostedt , Luca Abeni , Daniel Bristot de Oliveira , Wei Wang , Quentin Perret , Alessio Balsini , Pavan Kondeti , Patrick Bellasi , Morten Rasmussen , Valentin Schneider , Qais Yousef , linux-kernel@vger.kernel.org Subject: [PATCH v2 0/6] Capacity awareness for SCHED_DEADLINE Date: Mon, 27 Apr 2020 10:37:03 +0200 Message-Id: <20200427083709.30262-1-dietmar.eggemann@arm.com> X-Mailer: git-send-email 2.17.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The SCHED_DEADLINE (DL) admission control does not work correctly on heterogeneous (asymmetric CPU capacity) systems such as Arm big.LITTLE or DynamIQ. Let's fix this by explicitly considering CPU capacity in DL admission control and task migration. The DL sched class now attempts to avoid missing task deadlines due to smaller CPU (CPU capacity < 1024) not being capable enough to finish a task in time. It does so by trying to place a task so that its CPU capacity scaled deadline is not smaller than its runtime. This patch-set only supports capacity awareness in idle scenarios (cpudl::free_cpus not empty). Capacity awareness for non-idle cases should be added in a later series. Changes v1 [1] -> v2: Discussion about capacity awareness in idle and non-idle scenarios indicated that the current patch-set only supports the former. Per-patch changes: (1) Use rq->cpu_capacity_orig or capacity_orig_of() instead of arch_scale_cpu_capacity() [patch 1,6/6] (2) Optimize dl_bw_cpus(), i.e. return weight of rd->span if rd->span &sube cpu_active_mask [patch 2/6] (3) Replace rd_capacity() with dl_bw_capacity(). [patch 3/6] Changes RFC [2] -> v1: Only use static values for CPU bandwidth (sched_dl_entity::dl_runtime, ::dl_deadline) and CPU capacity (arch_scale_cpu_capacity()) to fix DL admission control. Dynamic values for CPU bandwidth (sched_dl_entity::runtime, ::deadline) and CPU capacity (capacity_of()) are considered to be more related to energy trade-off calculations which could be later introduced using the Energy Model. Since the design of the DL and RT sched classes are very similar, the implementation follows the overall design of RT capacity awareness (commit 804d402fb6f6 ("sched/rt: Make RT capacity-aware")). Per-patch changes: (1) Store CPU capacity sum in the root domain during build_sched_domains() [patch 1/4] (2) Adjust to RT capacity awareness design [patch 3/4] (3) Remove CPU capacity aware placement in switched_to_dl() (dl_migrate callback) [RFC patch 3/6] Balance callbacks (push, pull) run only in schedule_tail() __schedule(), rt_mutex_setprio() or __sched_setscheduler(). DL throttling leads to a call to __dequeue_task_dl() which is not a full task dequeue. The task is still enqueued and only removed from the rq. So a queue_balance_callback() call in update_curr_dl()-> __dequeue_task_dl() will not be followed by a balance_callback() call in one of the 4 functions mentioned above. (4) Remove 'dynamic CPU bandwidth' consideration and only support 'static CPU bandwidth' (ratio between sched_dl_entity::dl_runtime and ::dl_deadline) [RFC patch 4/6] (5) Remove modification to migration logic which tried to schedule small tasks on LITTLE CPUs [RFC patch 6/6] [1] https://lore.kernel.org/r/20200408095012.3819-1-dietmar.eggemann@arm.com [2] https://lore.kernel.org/r/20190506044836.2914-1-luca.abeni@santannapisa.it The following rt-app testcase tailored to Arm64 Hikey960: root@h960:~# cat /sys/devices/system/cpu/cpu*/cpu_capacity 462 462 462 462 1024 1024 1024 1024 shows the expected behavior. According to the following condition in dl_task_fits_capacity() cap_scale(dl_deadline, arch_scale_cpu_capacity(cpu)) >= dl_runtime thread0-[0-3] are placed on a big CPUs whereas thread1-[0-3] run on a LITTLE CPU respectively. ... "tasks" : { "thread0" : { "policy" : "SCHED_DEADLINE", "instance" : 4, "timer" : { "ref" : "unique0", "period" : 16000, "mode" : "absolute" }, "run" : 10000, "dl-runtime" : 11000, "dl-period" : 16000, "dl-deadline" : 16000 }, "thread1" : { "policy" : "SCHED_DEADLINE", "instance" : 4, "delay" : 1000, "timer" : { "ref" : "unique1", "period" : 16000, "mode" : "absolute" }, "run" : 5500, "dl-runtime" : 6500 "dl-period" : 16000, "dl-deadline" : 16000 } ... Tests were run with Performance CPUfreq governor so that the Schedutil CPUfreq governor DL threads (sugov:[0,4]), necessary on a slow-switching platform like Hikey960, do not interfere with the rt-app test tasks. Using Schedutil would require to lower the number of tasks to 3 instances each. Dietmar Eggemann (3): sched/topology: Store root domain CPU capacity sum sched/deadline: Optimize dl_bw_cpus() sched/deadline: Add dl_bw_capacity() Luca Abeni (3): sched/deadline: Improve admission control for asymmetric CPU capacities sched/deadline: Make DL capacity-aware sched/deadline: Implement fallback mechanism for !fit case kernel/sched/cpudeadline.c | 23 +++++++++++ kernel/sched/deadline.c | 80 +++++++++++++++++++++++++++++--------- kernel/sched/sched.h | 22 +++++++++-- kernel/sched/topology.c | 15 +++++-- 4 files changed, 115 insertions(+), 25 deletions(-) -- 2.17.1