diff options
Diffstat (limited to 'include/linux/pm_domain.h')
| -rw-r--r-- | include/linux/pm_domain.h | 28 | 
1 files changed, 24 insertions, 4 deletions
| diff --git a/include/linux/pm_domain.h b/include/linux/pm_domain.h index a09fe5c009c8..81ece61075df 100644 --- a/include/linux/pm_domain.h +++ b/include/linux/pm_domain.h @@ -15,11 +15,11 @@  #include <linux/err.h>  #include <linux/of.h>  #include <linux/notifier.h> +#include <linux/spinlock.h>  /* Defines used for the flags field in the struct generic_pm_domain */  #define GENPD_FLAG_PM_CLK	(1U << 0) /* PM domain uses PM clk */ - -#define GENPD_MAX_NUM_STATES	8 /* Number of possible low power states */ +#define GENPD_FLAG_IRQ_SAFE	(1U << 1) /* PM domain operates in atomic */  enum gpd_status {  	GPD_STATE_ACTIVE = 0,	/* PM domain is active */ @@ -40,15 +40,18 @@ struct gpd_dev_ops {  struct genpd_power_state {  	s64 power_off_latency_ns;  	s64 power_on_latency_ns; +	s64 residency_ns; +	struct fwnode_handle *fwnode;  }; +struct genpd_lock_ops; +  struct generic_pm_domain {  	struct dev_pm_domain domain;	/* PM domain operations */  	struct list_head gpd_list_node;	/* Node in the global PM domains list */  	struct list_head master_links;	/* Links with PM domain as a master */  	struct list_head slave_links;	/* Links with PM domain as a slave */  	struct list_head dev_list;	/* List of devices */ -	struct mutex lock;  	struct dev_power_governor *gov;  	struct work_struct power_off_work;  	struct fwnode_handle *provider;	/* Identity of the domain provider */ @@ -70,9 +73,18 @@ struct generic_pm_domain {  	void (*detach_dev)(struct generic_pm_domain *domain,  			   struct device *dev);  	unsigned int flags;		/* Bit field of configs for genpd */ -	struct genpd_power_state states[GENPD_MAX_NUM_STATES]; +	struct genpd_power_state *states;  	unsigned int state_count; /* number of states */  	unsigned int state_idx; /* state that genpd will go to when off */ +	void *free; /* Free the state that was allocated for default */ +	const struct genpd_lock_ops *lock_ops; +	union { +		struct mutex mlock; +		struct { +			spinlock_t slock; +			unsigned long lock_flags; +		}; +	};  }; @@ -205,6 +217,8 @@ extern int of_genpd_add_device(struct of_phandle_args *args,  extern int of_genpd_add_subdomain(struct of_phandle_args *parent,  				  struct of_phandle_args *new_subdomain);  extern struct generic_pm_domain *of_genpd_remove_last(struct device_node *np); +extern int of_genpd_parse_idle_states(struct device_node *dn, +			struct genpd_power_state **states, int *n);  int genpd_dev_pm_attach(struct device *dev);  #else /* !CONFIG_PM_GENERIC_DOMAINS_OF */ @@ -234,6 +248,12 @@ static inline int of_genpd_add_subdomain(struct of_phandle_args *parent,  	return -ENODEV;  } +static inline int of_genpd_parse_idle_states(struct device_node *dn, +			struct genpd_power_state **states, int *n) +{ +	return -ENODEV; +} +  static inline int genpd_dev_pm_attach(struct device *dev)  {  	return -ENODEV; |