diff options
Diffstat (limited to 'include')
| -rw-r--r-- | include/linux/pm.h | 37 | ||||
| -rw-r--r-- | include/linux/pm_runtime.h | 20 | 
2 files changed, 35 insertions, 22 deletions
| diff --git a/include/linux/pm.h b/include/linux/pm.h index 871c9c49ec9d..93cd34f00822 100644 --- a/include/linux/pm.h +++ b/include/linux/pm.h @@ -375,19 +375,20 @@ const struct dev_pm_ops name = { \  }  #ifdef CONFIG_PM -#define _EXPORT_DEV_PM_OPS(name, suspend_fn, resume_fn, runtime_suspend_fn, \ -			   runtime_resume_fn, idle_fn, sec, ns)		\ -	_DEFINE_DEV_PM_OPS(name, suspend_fn, resume_fn, runtime_suspend_fn, \ -			   runtime_resume_fn, idle_fn); \ -	__EXPORT_SYMBOL(name, sec, ns) +#define _EXPORT_DEV_PM_OPS(name, sec, ns)				\ +	const struct dev_pm_ops name;					\ +	__EXPORT_SYMBOL(name, sec, ns);					\ +	const struct dev_pm_ops name  #else -#define _EXPORT_DEV_PM_OPS(name, suspend_fn, resume_fn, runtime_suspend_fn, \ -			   runtime_resume_fn, idle_fn, sec, ns) \ -static __maybe_unused _DEFINE_DEV_PM_OPS(__static_##name, suspend_fn, \ -					 resume_fn, runtime_suspend_fn, \ -					 runtime_resume_fn, idle_fn) +#define _EXPORT_DEV_PM_OPS(name, sec, ns)				\ +	static __maybe_unused const struct dev_pm_ops __static_##name  #endif +#define EXPORT_DEV_PM_OPS(name) _EXPORT_DEV_PM_OPS(name, "", "") +#define EXPORT_GPL_DEV_PM_OPS(name) _EXPORT_DEV_PM_OPS(name, "_gpl", "") +#define EXPORT_NS_DEV_PM_OPS(name, ns) _EXPORT_DEV_PM_OPS(name, "", #ns) +#define EXPORT_NS_GPL_DEV_PM_OPS(name, ns) _EXPORT_DEV_PM_OPS(name, "_gpl", #ns) +  /*   * Use this if you want to use the same suspend and resume callbacks for suspend   * to RAM and hibernation. @@ -399,13 +400,21 @@ static __maybe_unused _DEFINE_DEV_PM_OPS(__static_##name, suspend_fn, \  	_DEFINE_DEV_PM_OPS(name, suspend_fn, resume_fn, NULL, NULL, NULL)  #define EXPORT_SIMPLE_DEV_PM_OPS(name, suspend_fn, resume_fn) \ -	_EXPORT_DEV_PM_OPS(name, suspend_fn, resume_fn, NULL, NULL, NULL, "", "") +	EXPORT_DEV_PM_OPS(name) = { \ +		SYSTEM_SLEEP_PM_OPS(suspend_fn, resume_fn) \ +	}  #define EXPORT_GPL_SIMPLE_DEV_PM_OPS(name, suspend_fn, resume_fn) \ -	_EXPORT_DEV_PM_OPS(name, suspend_fn, resume_fn, NULL, NULL, NULL, "_gpl", "") +	EXPORT_GPL_DEV_PM_OPS(name) = { \ +		SYSTEM_SLEEP_PM_OPS(suspend_fn, resume_fn) \ +	}  #define EXPORT_NS_SIMPLE_DEV_PM_OPS(name, suspend_fn, resume_fn, ns)	\ -	_EXPORT_DEV_PM_OPS(name, suspend_fn, resume_fn, NULL, NULL, NULL, "", #ns) +	EXPORT_NS_DEV_PM_OPS(name, ns) = { \ +		SYSTEM_SLEEP_PM_OPS(suspend_fn, resume_fn) \ +	}  #define EXPORT_NS_GPL_SIMPLE_DEV_PM_OPS(name, suspend_fn, resume_fn, ns)	\ -	_EXPORT_DEV_PM_OPS(name, suspend_fn, resume_fn, NULL, NULL, NULL, "_gpl", #ns) +	EXPORT_NS_GPL_DEV_PM_OPS(name, ns) = { \ +		SYSTEM_SLEEP_PM_OPS(suspend_fn, resume_fn) \ +	}  /* Deprecated. Use DEFINE_SIMPLE_DEV_PM_OPS() instead. */  #define SIMPLE_DEV_PM_OPS(name, suspend_fn, resume_fn) \ diff --git a/include/linux/pm_runtime.h b/include/linux/pm_runtime.h index 0a41b2dcccad..9a8151a2bdea 100644 --- a/include/linux/pm_runtime.h +++ b/include/linux/pm_runtime.h @@ -40,17 +40,21 @@  			   resume_fn, idle_fn)  #define EXPORT_RUNTIME_DEV_PM_OPS(name, suspend_fn, resume_fn, idle_fn) \ -	_EXPORT_DEV_PM_OPS(name, pm_runtime_force_suspend, pm_runtime_force_resume, \ -			   suspend_fn, resume_fn, idle_fn, "", "") +	EXPORT_DEV_PM_OPS(name) = { \ +		RUNTIME_PM_OPS(suspend_fn, resume_fn, idle_fn) \ +	}  #define EXPORT_GPL_RUNTIME_DEV_PM_OPS(name, suspend_fn, resume_fn, idle_fn) \ -	_EXPORT_DEV_PM_OPS(name, pm_runtime_force_suspend, pm_runtime_force_resume, \ -			   suspend_fn, resume_fn, idle_fn, "_gpl", "") +	EXPORT_GPL_DEV_PM_OPS(name) = { \ +		RUNTIME_PM_OPS(suspend_fn, resume_fn, idle_fn) \ +	}  #define EXPORT_NS_RUNTIME_DEV_PM_OPS(name, suspend_fn, resume_fn, idle_fn, ns) \ -	_EXPORT_DEV_PM_OPS(name, pm_runtime_force_suspend, pm_runtime_force_resume, \ -			   suspend_fn, resume_fn, idle_fn, "", #ns) +	EXPORT_NS_DEV_PM_OPS(name, ns) = { \ +		RUNTIME_PM_OPS(suspend_fn, resume_fn, idle_fn) \ +	}  #define EXPORT_NS_GPL_RUNTIME_DEV_PM_OPS(name, suspend_fn, resume_fn, idle_fn, ns) \ -	_EXPORT_DEV_PM_OPS(name, pm_runtime_force_suspend, pm_runtime_force_resume, \ -			   suspend_fn, resume_fn, idle_fn, "_gpl", #ns) +	EXPORT_NS_GPL_DEV_PM_OPS(name, ns) = { \ +		RUNTIME_PM_OPS(suspend_fn, resume_fn, idle_fn) \ +	}  #ifdef CONFIG_PM  extern struct workqueue_struct *pm_wq; | 
