From patchwork Wed Apr 15 22:53:49 2009 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Darrick J. Wong" X-Patchwork-Id: 18428 Received: from vger.kernel.org (vger.kernel.org [209.132.176.167]) by demeter.kernel.org (8.14.2/8.14.2) with ESMTP id n3FMsIvb024305 for ; Wed, 15 Apr 2009 22:54:18 GMT Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755980AbZDOWx4 (ORCPT ); Wed, 15 Apr 2009 18:53:56 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1756606AbZDOWxz (ORCPT ); Wed, 15 Apr 2009 18:53:55 -0400 Received: from e8.ny.us.ibm.com ([32.97.182.138]:59066 "EHLO e8.ny.us.ibm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755980AbZDOWxw (ORCPT ); Wed, 15 Apr 2009 18:53:52 -0400 Received: from d01relay02.pok.ibm.com (d01relay02.pok.ibm.com [9.56.227.234]) by e8.ny.us.ibm.com (8.13.1/8.13.1) with ESMTP id n3FMitle009046; Wed, 15 Apr 2009 18:44:55 -0400 Received: from d01av02.pok.ibm.com (d01av02.pok.ibm.com [9.56.224.216]) by d01relay02.pok.ibm.com (8.13.8/8.13.8/NCO v9.2) with ESMTP id n3FMro5s183716; Wed, 15 Apr 2009 18:53:50 -0400 Received: from d01av02.pok.ibm.com (loopback [127.0.0.1]) by d01av02.pok.ibm.com (8.12.11.20060308/8.13.3) with ESMTP id n3FMq7o1024571; Wed, 15 Apr 2009 18:52:07 -0400 Received: from localhost (plum.beaverton.ibm.com [9.47.17.113]) by d01av02.pok.ibm.com (8.12.11.20060308/8.12.11) with ESMTP id n3FMq7Wq024565; Wed, 15 Apr 2009 18:52:07 -0400 Date: Wed, 15 Apr 2009 15:53:49 -0700 From: "Darrick J. Wong" To: linux-kernel Cc: Ingo Molnar , Thomas Renninger , cpufreq@vger.kernel.org, linux-acpi@vger.kernel.org Subject: [PATCH] acpi: Fix regression where _PPC is not read at boot even when ignore_ppc=0 Message-ID: <20090415225348.GW8311@plum> Reply-To: djwong@us.ibm.com MIME-Version: 1.0 Content-Disposition: inline User-Agent: Mutt/1.5.18 (2008-05-17) Sender: linux-acpi-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-acpi@vger.kernel.org Earlier, Ingo Molnar posted a patch to make it so that the kernel would avoid reading _PPC on his broken T60. Unfortunately, it seems that with Thomas Renninger's patch last July to eliminate _PPC evaluations when the processor driver loads, the kernel never actually reads _PPC at all! This is problematic if you happen to boot your non-T60 computer in a state where the BIOS _wants_ _PPC to be something other than zero. So, put the _PPC evaluation back into acpi_processor_get_performance_info if ignore_ppc isn't 1. Signed-off-by: Darrick J. Wong --- drivers/acpi/processor_perflib.c | 19 ++++++++++++++----- 1 files changed, 14 insertions(+), 5 deletions(-) -- To unsubscribe from this list: send the line "unsubscribe linux-acpi" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html diff --git a/drivers/acpi/processor_perflib.c b/drivers/acpi/processor_perflib.c index cafb410..0b50e8e 100644 --- a/drivers/acpi/processor_perflib.c +++ b/drivers/acpi/processor_perflib.c @@ -150,13 +150,10 @@ static int acpi_processor_get_platform_limit(struct acpi_processor *pr) return 0; } -int acpi_processor_ppc_has_changed(struct acpi_processor *pr) +static int __acpi_processor_ppc_has_changed(struct acpi_processor *pr) { int ret; - if (ignore_ppc) - return 0; - ret = acpi_processor_get_platform_limit(pr); if (ret < 0) @@ -165,6 +162,14 @@ int acpi_processor_ppc_has_changed(struct acpi_processor *pr) return cpufreq_update_policy(pr->id); } +int acpi_processor_ppc_has_changed(struct acpi_processor *pr) +{ + if (ignore_ppc) + return 0; + + return __acpi_processor_ppc_has_changed(pr); +} + void acpi_processor_ppc_init(void) { if (!cpufreq_register_notifier @@ -348,7 +353,11 @@ static int acpi_processor_get_performance_info(struct acpi_processor *pr) if (result) goto update_bios; - return 0; + /* We need to call _PPC once when cpufreq starts */ + if (ignore_ppc != 1) + result = __acpi_processor_ppc_has_changed(pr); + + return result; /* * Having _PPC but missing frequencies (_PSS, _PCT) is a very good hint that