Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751460AbdGZRek (ORCPT ); Wed, 26 Jul 2017 13:34:40 -0400 Received: from cloudserver094114.home.net.pl ([79.96.170.134]:49989 "EHLO cloudserver094114.home.net.pl" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751413AbdGZRej (ORCPT ); Wed, 26 Jul 2017 13:34:39 -0400 From: "Rafael J. Wysocki" To: Viresh Kumar Cc: Peter Zijlstra , Srinivas Pandruvada , Len Brown , Ingo Molnar , linux-pm@vger.kernel.org, Vincent Guittot , smuckle.linux@gmail.com, juri.lelli@arm.com, Morten.Rasmussen@arm.com, patrick.bellasi@arm.com, eas-dev@lists.linaro.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH V3 1/3] sched: cpufreq: Allow remote cpufreq callbacks Date: Wed, 26 Jul 2017 19:26:38 +0200 Message-ID: <2367709.KiRkWci6fx@aspire.rjw.lan> User-Agent: KMail/4.14.10 (Linux/4.12.0-rc1+; KDE/4.14.9; x86_64; ; ) In-Reply-To: <20170726062912.GA352@vireshk-i7> References: <20170724134752.sejehwa5mjqqc2mq@hirez.programming.kicks-ass.net> <20170726062912.GA352@vireshk-i7> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1622 Lines: 43 On Wednesday, July 26, 2017 11:59:12 AM Viresh Kumar wrote: > On 24-07-17, 15:47, Peter Zijlstra wrote: > > I said nothing about the shared locking. That is indeed required. All I > > said is that those two tests you add could be left out. > > I was right, I didn't understood your comment at all :( > > > > > That would then continue to process the iowait and other accounting > > > > stuff, but stall the moment we call into the actual driver, which will > > > > then drop the request on the floor as per the first few hunks. > > > > > > I am not sure I understood your comment completely though. > > > > Since we call cpufreq_update_util(@rq, ...) with @rq->lock held, all > > such calls are in fact serialized for that cpu. > > Yes, they are serialized but .. > > > Therefore the cpu != > > current_cpu test you add are pointless. > > .. I didn't understand why you said so. This check isn't there to take > care of serialization but remote callbacks. > > > Only once we get to the actual cpufreq driver (intel_pstate and others) > > do we run into the fact that we might not be able to service the request > > remotely. > > We never check for remote callbacks in drivers. > > > But since you also add a test there, that is sufficient. > > No. > > The diff for intel-pstate that you saw in this patch was for the case > where intel-pstate works directly with the scheduler (i.e. no > schedutil governor). The routine that gets called with schedutil is > intel_cpufreq_target(), which doesn't check for remoteness at all. And of course acpi-cpufreq doesn't check for that too, for example. Thanks, Rafael