On Tue, 5 Oct 2010 09:48:42 +0100 Andy Whitcroft <apw@xxxxxxxxxxxxx> wrote: > Both when polling the current turbo status (in poll_turbo_status mode) > and when handling thermal events (in ips_irq_handler) the current status > of GPU turbo is updated to match the hardware status. However if during > driver initialisation we were unable aquire linkage to the i915 driver > enabling GPU turbo will lead to an oops on the first attempt to determine > GPU busy status. > > Ensure that we do not enable GPU turbo unless we have driver linkage. > > BugLink: http://bugs.launchpad.net/bugs/632430 > Cc: stable@xxxxxxxxxx > Signed-off-by: Andy Whitcroft <apw@xxxxxxxxxxxxx> > --- > drivers/platform/x86/intel_ips.c | 6 ++++-- > 1 files changed, 4 insertions(+), 2 deletions(-) > > diff --git a/drivers/platform/x86/intel_ips.c b/drivers/platform/x86/intel_ips.c > index afe82e5..3ca50b3 100644 > --- a/drivers/platform/x86/intel_ips.c > +++ b/drivers/platform/x86/intel_ips.c > @@ -680,7 +680,8 @@ static void update_turbo_limits(struct ips_driver *ips) > u32 hts = thm_readl(THM_HTS); > > ips->cpu_turbo_enabled = !(hts & HTS_PCTD_DIS); > - ips->gpu_turbo_enabled = !(hts & HTS_GTD_DIS); > + if (ips->gpu_busy) > + ips->gpu_turbo_enabled = !(hts & HTS_GTD_DIS); > ips->core_power_limit = thm_readw(THM_MPCPC); > ips->mch_power_limit = thm_readw(THM_MMGPC); > ips->mcp_temp_limit = thm_readw(THM_PTL); > @@ -1150,7 +1151,8 @@ static irqreturn_t ips_irq_handler(int irq, void *arg) > STS_GPL_SHIFT; > /* ignore EC CPU vs GPU pref */ > ips->cpu_turbo_enabled = !(sts & STS_PCTD_DIS); > - ips->gpu_turbo_enabled = !(sts & STS_GTD_DIS); > + if (ips->gpu_busy) > + ips->gpu_turbo_enabled = !(sts & STS_GTD_DIS); > ips->mcp_temp_limit = (sts & STS_PTL_MASK) >> > STS_PTL_SHIFT; > ips->mcp_power_limit = (tc1 & STS_PPL_MASK) >> Looks good, thanks. Most of the performance upside is on the GPU, so running without i915 is a shame, but we definitely shouldn't oops, so this patch looks fine. Acked-by: Jesse Barnes <jbarnes@xxxxxxxxxxxxxxxx> -- Jesse Barnes, Intel Open Source Technology Center -- To unsubscribe from this list: send the line "unsubscribe platform-driver-x86" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html