Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S934171AbcCPQ6W (ORCPT ); Wed, 16 Mar 2016 12:58:22 -0400 Received: from mail-lf0-f66.google.com ([209.85.215.66]:35428 "EHLO mail-lf0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932079AbcCPQ6U (ORCPT ); Wed, 16 Mar 2016 12:58:20 -0400 MIME-Version: 1.0 In-Reply-To: <20160316154314.GB6344@twins.programming.kicks-ass.net> References: <1711281.bPmSjlBT7c@vostro.rjw.lan> <1989596.XAKfhFj1lz@vostro.rjw.lan> <20160316154314.GB6344@twins.programming.kicks-ass.net> Date: Wed, 16 Mar 2016 17:58:18 +0100 X-Google-Sender-Auth: _bJsk1KIwjWQ5zIemT8TqA1KVUo Message-ID: Subject: Re: [PATCH v4 6/7] cpufreq: Support for fast frequency switching From: "Rafael J. Wysocki" To: Peter Zijlstra Cc: "Rafael J. Wysocki" , Linux PM list , Juri Lelli , Steve Muckle , ACPI Devel Maling List , Linux Kernel Mailing List , Srinivas Pandruvada , Viresh Kumar , Vincent Guittot , Michael Turquette , Ingo Molnar Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1453 Lines: 39 On Wed, Mar 16, 2016 at 4:43 PM, Peter Zijlstra wrote: > On Wed, Mar 16, 2016 at 03:52:28PM +0100, Rafael J. Wysocki wrote: >> +void cpufreq_enable_fast_switch(struct cpufreq_policy *policy) >> +{ >> + mutex_lock(&cpufreq_fast_switch_lock); >> + if (policy->fast_switch_possible && cpufreq_fast_switch_count >= 0) { >> + cpufreq_fast_switch_count++; >> + policy->fast_switch_enabled = true; >> + } else { >> + pr_warn("cpufreq: CPU%u: Fast freqnency switching not enabled\n", >> + policy->cpu); > > This happens because there's transition notifiers, right? Would it make > sense to iterate the notifier here and print the notifier function > symbol for each? That way we've got a clue as to where to start looking > when this happens. OK >> + } >> + mutex_unlock(&cpufreq_fast_switch_lock); >> +} > >> @@ -1653,8 +1703,18 @@ int cpufreq_register_notifier(struct not >> >> switch (list) { >> case CPUFREQ_TRANSITION_NOTIFIER: >> + mutex_lock(&cpufreq_fast_switch_lock); >> + >> + if (cpufreq_fast_switch_count > 0) { >> + mutex_unlock(&cpufreq_fast_switch_lock); > > So while theoretically (it has a return code) > cpufreq_register_notifier() could fail, it never actually did. Now we > do. Do we want to add a WARN here? Like if (WARN_ON(cpufreq_fast_switch_count > 0)) { That can be done. :-)