Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757299AbcCWVYf (ORCPT ); Wed, 23 Mar 2016 17:24:35 -0400 Received: from v094114.home.net.pl ([79.96.170.134]:55189 "HELO v094114.home.net.pl" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with SMTP id S1756980AbcCWVYd (ORCPT ); Wed, 23 Mar 2016 17:24:33 -0400 From: "Rafael J. Wysocki" To: Richard Cochran Cc: linux-kernel@vger.kernel.org, rt@linutronix.de, Viresh Kumar , linux-pm@vger.kernel.org Subject: Re: [PATCH 5/5] cpufreq: acpi-cpufreq: Clean up hot plug notifier callback. Date: Wed, 23 Mar 2016 22:26:45 +0100 Message-ID: <6345603.OpCxeV2k9k@vostro.rjw.lan> User-Agent: KMail/4.11.5 (Linux/4.5.0-rc1+; KDE/4.11.5; x86_64; ; ) In-Reply-To: <1458336371-17748-5-git-send-email-rcochran@linutronix.de> References: <1458336371-17748-5-git-send-email-rcochran@linutronix.de> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit 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: 1469 Lines: 38 On Friday, March 18, 2016 10:26:11 PM Richard Cochran wrote: > This driver has two issues. First, it tries to fiddle with the hot > plugged CPU's MSR on the UP_PREPARE event, at a time when the CPU is > not yet online. Second, the driver sets the "boost-disable" bit for a > CPU when going down, but does not clear the bit again if the CPU comes > up again due to DOWN_FAILED. > > This patch fixes the issues by changing the driver to react to the > ONLINE/DOWN_FAILED events instead of UP_PREPARE. As an added benefit, > the driver also becomes symmetric with respect to the hot plug > mechanism. > > Cc: "Rafael J. Wysocki" > Cc: Viresh Kumar > Cc: linux-pm@vger.kernel.org > Signed-off-by: Richard Cochran > --- > drivers/cpufreq/acpi-cpufreq.c | 6 ++++-- > 1 file changed, 4 insertions(+), 2 deletions(-) > > diff --git a/drivers/cpufreq/acpi-cpufreq.c b/drivers/cpufreq/acpi-cpufreq.c > index 51eef87..7006a43 100644 > --- a/drivers/cpufreq/acpi-cpufreq.c > +++ b/drivers/cpufreq/acpi-cpufreq.c > @@ -540,8 +540,10 @@ static int boost_notify(struct notifier_block *nb, unsigned long action, > */ > > switch (action) { > - case CPU_UP_PREPARE: > - case CPU_UP_PREPARE_FROZEN: > + case CPU_DOWN_FAILED: > + case CPU_DOWN_FAILED_FROZEN: > + case CPU_ONLINE: > + case CPU_ONLINE_FROZEN: > boost_set_msrs(acpi_cpufreq_driver.boost_enabled, cpumask); > break; Applied, thanks!