linux-pm.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Zhang Rui <rui.zhang@intel.com>
To: Jacob Pan <jacob.jun.pan@linux.intel.com>
Cc: Linux PM <linux-pm@vger.kernel.org>,
	LKML <linux-kernel@vger.kernel.org>,
	Peter Zijlstra <a.p.zijlstra@chello.nl>,
	Rafael Wysocki <rafael.j.wysocki@intel.com>,
	Len Brown <len.brown@intel.com>,
	Thomas Gleixner <tglx@linutronix.de>,
	"H. Peter Anvin" <hpa@zytor.com>, Ingo Molnar <mingo@elte.hu>,
	Joe Perches <joe@perches.com>, Rob Landley <rob@landley.net>,
	Arjan van de Ven <arjan@linux.intel.com>,
	Paul McKenney <paulmck@linux.vnet.ibm.com>
Subject: Re: [PATCH v6 3/3] PM: Introduce Intel PowerClamp Driver
Date: Wed, 16 Jan 2013 20:20:08 +0800	[thread overview]
Message-ID: <1358338808.2252.54.camel@rzhang1-mobl4> (raw)
In-Reply-To: <1358338729.2252.53.camel@rzhang1-mobl4>

On Wed, 2013-01-16 at 20:18 +0800, Zhang Rui wrote:
> Hi, Jacob,
> 
> On Fri, 2013-01-04 at 03:12 -0800, Jacob Pan wrote:
> > Intel PowerClamp driver performs synchronized idle injection across
> > all online CPUs. The goal is to maintain a given package level C-state
> > ratio.
> > 
> > Compared to other throttling methods already exist in the kernel,
> > such as ACPI PAD (taking CPUs offline) and clock modulation, this is often
> > more efficient in terms of performance per watt.
> > 
> > Please refer to Documentation/thermal/intel_powerclamp.txt for more details.
> > 
> > Signed-off-by: Arjan van de Ven <arjan@linux.intel.com>
> > Signed-off-by: Jacob Pan <jacob.jun.pan@linux.intel.com>
> > ---
> >  Documentation/thermal/intel_powerclamp.txt |  307 +++++++++++
> >  drivers/thermal/Kconfig                    |   10 +
> >  drivers/thermal/Makefile                   |    2 +
> >  drivers/thermal/intel_powerclamp.c         |  788 ++++++++++++++++++++++++++++
> >  4 files changed, 1107 insertions(+)
> >  create mode 100644 Documentation/thermal/intel_powerclamp.txt
> >  create mode 100644 drivers/thermal/intel_powerclamp.c
> 
> > diff --git a/drivers/thermal/Kconfig b/drivers/thermal/Kconfig
> > index c2c77d1..7d90ab8 100644
> > --- a/drivers/thermal/Kconfig
> > +++ b/drivers/thermal/Kconfig
> > @@ -122,4 +122,14 @@ config DB8500_CPUFREQ_COOLING
> >  	  bound cpufreq cooling device turns active to set CPU frequency low to
> >  	  cool down the CPU.
> >  
> > +config INTEL_POWERCLAMP
> > +	tristate "Intel PowerClamp idle injection driver"
> > +	depends on THERMAL
> > +	depends on X86
> > +	depends on CPU_SUP_INTEL
> > +	help
> > +	  Enable this to enable Intel PowerClamp idle injection driver. This
> > +	  enforce idle time which results in more package C-state residency. The
> > +	  user interface is exposed via generic thermal framework.
> > +
> >  endif
> > diff --git a/drivers/thermal/Makefile b/drivers/thermal/Makefile
> > index d8da683..574f5f5 100644
> > --- a/drivers/thermal/Makefile
> > +++ b/drivers/thermal/Makefile
> > @@ -18,3 +18,5 @@ obj-$(CONFIG_RCAR_THERMAL)	+= rcar_thermal.o
> >  obj-$(CONFIG_EXYNOS_THERMAL)	+= exynos_thermal.o
> >  obj-$(CONFIG_DB8500_THERMAL)	+= db8500_thermal.o
> >  obj-$(CONFIG_DB8500_CPUFREQ_COOLING)	+= db8500_cpufreq_cooling.o
> > +obj-$(CONFIG_INTEL_POWERCLAMP)	+= intel_powerclamp.o
> > +
> > diff --git a/drivers/thermal/intel_powerclamp.c b/drivers/thermal/intel_powerclamp.c
> > new file mode 100644
> > index 0000000..314b6fc
> > --- /dev/null
> > +++ b/drivers/thermal/intel_powerclamp.c
> > @@ -0,0 +1,788 @@
> > +/*
> > + * intel_powerclamp.c - package c-state idle injection
> > + *
> > + * Copyright (c) 2012, Intel Corporation.
> > + *
> > + * Authors:
> > + *     Arjan van de Ven <arjan@linux.intel.com>
> > + *     Jacob Pan <jacob.jun.pan@linux.intel.com>
> > + *
> > + * This program is free software; you can redistribute it and/or modify it
> > + * under the terms and conditions of the GNU General Public License,
> > + * version 2, as published by the Free Software Foundation.
> > + *
> > + * This program is distributed in the hope it will be useful, but WITHOUT
> > + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
> > + * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
> > + * more details.
> > + *
> > + * You should have received a copy of the GNU General Public License along with
> > + * this program; if not, write to the Free Software Foundation, Inc.,
> > + * 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
> > + *
> > + *
> > + *	TODO:
> > + *           1. better handle wakeup from external interrupts, currently a fixed
> > + *              compensation is added to clamping duration when excessive amount
> > + *              of wakeups are observed during idle time. the reason is that in
> > + *              case of external interrupts without need for ack, clamping down
> > + *              cpu in non-irq context does not reduce irq. for majority of the
> > + *              cases, clamping down cpu does help reduce irq as well, we should
> > + *              be able to differenciate the two cases and give a quantitative
> > + *              solution for the irqs that we can control. perhaps based on
> > + *              get_cpu_iowait_time_us()
> > + *
> > + *	     2. synchronization with other hw blocks
> > + *
> > + *
> > + */
> > +
> > +#define pr_fmt(fmt)	KBUILD_MODNAME ": " fmt
> > +
> > +#include <linux/module.h>
> > +#include <linux/kernel.h>
> > +#include <linux/delay.h>
> > +#include <linux/kthread.h>
> > +#include <linux/freezer.h>
> > +#include <linux/cpu.h>
> > +#include <linux/thermal.h>
> > +#include <linux/slab.h>
> > +#include <linux/tick.h>
> > +#include <linux/debugfs.h>
> > +#include <linux/seq_file.h>
> > +#include <linux/nmi.h>
> > +
> drivers/thermal/intel_powerclamp.c: In function ‘clamp_thread’:
> drivers/thermal/intel_powerclamp.c:435:4: error: implicit declaration of
> function ‘local_touch_nmi’ [-Werror=implicit-function-declaration]
> 
> changing to 
> #include <asm/nmi.h>
> fixes the problem.
> 
and this is because I have neither CONFIG_HAVE_NMI_WATCHDOG set nor
CONFIG_HARDLOCKUP_DETECTOR set in my configuration. :)

thanks,
rui


  reply	other threads:[~2013-01-16 12:20 UTC|newest]

Thread overview: 10+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-01-04 11:12 [PATCH v6 0/3] PM: Intel PowerClamp driver Jacob Pan
2013-01-04 11:12 ` [PATCH v6 1/3] tick: export nohz tick idle symbols for module use Jacob Pan
2013-01-17 14:34   ` Zhang Rui
2013-01-04 11:12 ` [PATCH v6 2/3] x86/nmi: export local_touch_nmi() symbol for modules Jacob Pan
2013-01-17 14:35   ` Zhang Rui
2013-01-04 11:12 ` [PATCH v6 3/3] PM: Introduce Intel PowerClamp Driver Jacob Pan
2013-01-16 12:18   ` Zhang Rui
2013-01-16 12:20     ` Zhang Rui [this message]
2013-01-16 17:09     ` jacob pan
2013-01-11 22:37 ` [PATCH v6 0/3] PM: Intel PowerClamp driver Rafael J. Wysocki

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1358338808.2252.54.camel@rzhang1-mobl4 \
    --to=rui.zhang@intel.com \
    --cc=a.p.zijlstra@chello.nl \
    --cc=arjan@linux.intel.com \
    --cc=hpa@zytor.com \
    --cc=jacob.jun.pan@linux.intel.com \
    --cc=joe@perches.com \
    --cc=len.brown@intel.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-pm@vger.kernel.org \
    --cc=mingo@elte.hu \
    --cc=paulmck@linux.vnet.ibm.com \
    --cc=rafael.j.wysocki@intel.com \
    --cc=rob@landley.net \
    --cc=tglx@linutronix.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).