diff options
| author | Rajagopal Venkat <rajagopal.venkat@linaro.org> | 2012-10-26 01:50:18 +0200 | 
|---|---|---|
| committer | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2012-11-15 00:35:04 +0100 | 
| commit | 206c30cfeb7c05dfb9fdfd81b1deb933627e43c1 (patch) | |
| tree | 0cc26302a81b78cf7d790e0483d2734753cf3d04 | |
| parent | 7e6fdd4bad033fa2d73716377b184fa975b0d985 (diff) | |
| download | olio-linux-3.10-206c30cfeb7c05dfb9fdfd81b1deb933627e43c1.tar.xz olio-linux-3.10-206c30cfeb7c05dfb9fdfd81b1deb933627e43c1.zip  | |
PM / devfreq: Add suspend and resume apis
Add devfreq suspend/resume apis for devfreq users. This patch
supports suspend and resume of devfreq load monitoring, required
for devices which can idle.
Signed-off-by: Rajagopal Venkat <rajagopal.venkat@linaro.org>
Acked-by: MyungJoo Ham <myungjoo.ham@samsung.com>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
| -rw-r--r-- | drivers/devfreq/devfreq.c | 28 | ||||
| -rw-r--r-- | drivers/devfreq/governor.h | 2 | ||||
| -rw-r--r-- | drivers/devfreq/governor_simpleondemand.c | 9 | ||||
| -rw-r--r-- | include/linux/devfreq.h | 12 | 
4 files changed, 51 insertions, 0 deletions
diff --git a/drivers/devfreq/devfreq.c b/drivers/devfreq/devfreq.c index 1aaf1aeb1f1..999600da21c 100644 --- a/drivers/devfreq/devfreq.c +++ b/drivers/devfreq/devfreq.c @@ -427,6 +427,34 @@ int devfreq_remove_device(struct devfreq *devfreq)  }  EXPORT_SYMBOL(devfreq_remove_device); +/** + * devfreq_suspend_device() - Suspend devfreq of a device. + * @devfreq: the devfreq instance to be suspended + */ +int devfreq_suspend_device(struct devfreq *devfreq) +{ +	if (!devfreq) +		return -EINVAL; + +	return devfreq->governor->event_handler(devfreq, +				DEVFREQ_GOV_SUSPEND, NULL); +} +EXPORT_SYMBOL(devfreq_suspend_device); + +/** + * devfreq_resume_device() - Resume devfreq of a device. + * @devfreq: the devfreq instance to be resumed + */ +int devfreq_resume_device(struct devfreq *devfreq) +{ +	if (!devfreq) +		return -EINVAL; + +	return devfreq->governor->event_handler(devfreq, +				DEVFREQ_GOV_RESUME, NULL); +} +EXPORT_SYMBOL(devfreq_resume_device); +  static ssize_t show_governor(struct device *dev,  			     struct device_attribute *attr, char *buf)  { diff --git a/drivers/devfreq/governor.h b/drivers/devfreq/governor.h index bb3aff32d62..26432ac0a39 100644 --- a/drivers/devfreq/governor.h +++ b/drivers/devfreq/governor.h @@ -22,6 +22,8 @@  #define DEVFREQ_GOV_START			0x1  #define DEVFREQ_GOV_STOP			0x2  #define DEVFREQ_GOV_INTERVAL			0x3 +#define DEVFREQ_GOV_SUSPEND			0x4 +#define DEVFREQ_GOV_RESUME			0x5  /* Caution: devfreq->lock must be locked before calling update_devfreq */  extern int update_devfreq(struct devfreq *devfreq); diff --git a/drivers/devfreq/governor_simpleondemand.c b/drivers/devfreq/governor_simpleondemand.c index 3716a659122..b5cf0fb24ef 100644 --- a/drivers/devfreq/governor_simpleondemand.c +++ b/drivers/devfreq/governor_simpleondemand.c @@ -104,6 +104,15 @@ static int devfreq_simple_ondemand_handler(struct devfreq *devfreq,  	case DEVFREQ_GOV_INTERVAL:  		devfreq_interval_update(devfreq, (unsigned int *)data);  		break; + +	case DEVFREQ_GOV_SUSPEND: +		devfreq_monitor_suspend(devfreq); +		break; + +	case DEVFREQ_GOV_RESUME: +		devfreq_monitor_resume(devfreq); +		break; +  	default:  		break;  	} diff --git a/include/linux/devfreq.h b/include/linux/devfreq.h index 9cdffde74bb..ee243a3229b 100644 --- a/include/linux/devfreq.h +++ b/include/linux/devfreq.h @@ -158,6 +158,8 @@ extern struct devfreq *devfreq_add_device(struct device *dev,  				  const struct devfreq_governor *governor,  				  void *data);  extern int devfreq_remove_device(struct devfreq *devfreq); +extern int devfreq_suspend_device(struct devfreq *devfreq); +extern int devfreq_resume_device(struct devfreq *devfreq);  /* Helper functions for devfreq user device driver with OPP. */  extern struct opp *devfreq_recommended_opp(struct device *dev, @@ -211,6 +213,16 @@ static int devfreq_remove_device(struct devfreq *devfreq)  	return 0;  } +static int devfreq_suspend_device(struct devfreq *devfreq) +{ +	return 0; +} + +static int devfreq_resume_device(struct devfreq *devfreq) +{ +	return 0; +} +  static struct opp *devfreq_recommended_opp(struct device *dev,  					   unsigned long *freq, u32 flags)  {  |