Received: by 2002:ac0:a591:0:0:0:0:0 with SMTP id m17-v6csp638055imm; Thu, 5 Jul 2018 06:32:56 -0700 (PDT) X-Google-Smtp-Source: AAOMgpeWmirvKfNJVh8o8C7U6tiiUZkg4KwfFSB/IGSWiBdwpjnZU/kp6R4r9DGgrRpYDxY6lxcy X-Received: by 2002:a65:510c:: with SMTP id f12-v6mr5523482pgq.288.1530797576062; Thu, 05 Jul 2018 06:32:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1530797576; cv=none; d=google.com; s=arc-20160816; b=UNknsWNOErFn2TEmFGW3x+Bs6bQBWKT0kK5/A9LrUNSLpS95kdBkO0yGdN5GPQarh8 hNaKCBLpyOT9X/TwQhPPSH0FA7hTPktpfej2M9prV70MmZ3QAEAdUXRgXVS3GQKwpTUw /X25hE/MHP/ce6QGNk7YdCVHIYWV8jEraWUPaZEO6VZY41LOGH2RnXaRGj8ic5Ck5aP4 SFM52+7wssVJNxHXlqL6e6NUqXrE/YbVZxXD8y8VO3+5KFnmmdWy8NKW2zPf8AsamTl/ dHmqCKV9l2NsenFCGJMXXQoc/2Bfso8R1RW0hWFc01yxypGskm/w2XWYSwAS/6gFG2R/ xf0Q== 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:arc-authentication-results; bh=9KW0grJK/SpUQYtOcKVVv/Rn+KrvNpl0tCllExfvlu4=; b=EtFgHz6uwMGpVHMZ126eMuytuRm2VslJLkjdUjickgxbWhLvIWaXeghxOhd951ropC nY7F9SySVWLiCvTJzKxSO7OkmB0T4Bi+kgLhhSwmWAMrMLpNIuvbo45FM0ww6+A/fz6n 1ZJ9hG5KD4wkkEr7RA0CAZUu7iROh+PPF5c9LCdOksUqKnHwJIQqYIgwB5rirBTSSBa9 TJKUjAQ2vuQywV3+7phff+85Q/iaHahq8IqPdYXPrmVLFHVoefICKTovbVQWje87qtrI yNkCQ9lyZSd6XyBwz8zRyK/qPzDICaTqgl+h7ludBnHrxbLE8J6wqsJEFjo0B4FXmADh 3szw== ARC-Authentication-Results: i=1; mx.google.com; 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 r5-v6si5562782pga.602.2018.07.05.06.32.41; Thu, 05 Jul 2018 06:32:56 -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; 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 S1753421AbeGENbr (ORCPT + 99 others); Thu, 5 Jul 2018 09:31:47 -0400 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:49740 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753194AbeGENbq (ORCPT ); Thu, 5 Jul 2018 09:31:46 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 65EF018A; Thu, 5 Jul 2018 06:31:46 -0700 (PDT) Received: from e108498-lin.cambridge.arm.com (e108498-lin.cambridge.arm.com [10.1.211.46]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id D72623F5AD; Thu, 5 Jul 2018 06:31:44 -0700 (PDT) Date: Thu, 5 Jul 2018 14:31:43 +0100 From: Quentin Perret To: Morten Rasmussen Cc: peterz@infradead.org, mingo@redhat.com, valentin.schneider@arm.com, dietmar.eggemann@arm.com, vincent.guittot@linaro.org, gaku.inami.xh@renesas.com, linux-kernel@vger.kernel.org Subject: Re: [PATCHv4 11/12] sched/core: Disable SD_ASYM_CPUCAPACITY for root_domains without asymmetry Message-ID: <20180705133142.GD32579@e108498-lin.cambridge.arm.com> References: <1530699470-29808-1-git-send-email-morten.rasmussen@arm.com> <1530699470-29808-12-git-send-email-morten.rasmussen@arm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1530699470-29808-12-git-send-email-morten.rasmussen@arm.com> User-Agent: Mutt/1.8.3 (2017-05-23) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Morten, On Wednesday 04 Jul 2018 at 11:17:49 (+0100), Morten Rasmussen wrote: > diff --git a/kernel/sched/topology.c b/kernel/sched/topology.c > index 71330e0e41db..29c186961345 100644 > --- a/kernel/sched/topology.c > +++ b/kernel/sched/topology.c > @@ -1160,6 +1160,26 @@ sd_init(struct sched_domain_topology_level *tl, > sd_id = cpumask_first(sched_domain_span(sd)); > > /* > + * Check if cpu_map eclipses cpu capacity asymmetry. > + */ > + > + if (sd->flags & SD_ASYM_CPUCAPACITY) { > + int i; > + bool disable = true; > + long capacity = arch_scale_cpu_capacity(NULL, sd_id); > + > + for_each_cpu(i, sched_domain_span(sd)) { > + if (capacity != arch_scale_cpu_capacity(NULL, i)) { > + disable = false; > + break; > + } > + } > + > + if (disable) > + sd->flags &= ~SD_ASYM_CPUCAPACITY; > + } > + > + /* > * Convert topological properties into behaviour. > */ If SD_ASYM_CPUCAPACITY means that some CPUs have different arch_scale_cpu_capacity() values, we could also automatically _set_ the flag in sd_init() no ? Why should we let the arch set it and just correct it later ? I understand the moment at which we know the capacities of CPUs varies from arch to arch, but the arch code could just call rebuild_sched_domain when the capacities of CPUs change and let the scheduler detect things automatically. I mean, even if the arch code sets the flag in its topology level table, it will have to rebuild the sched domains anyway ... What do you think ? Thanks, Quentin