You've already forked linux-apfs
mirror of
https://github.com/linux-apfs/linux-apfs.git
synced 2026-05-01 15:00:59 -07:00
Merge remote-tracking branch 'regulator/topic/core' into regulator-next
This commit is contained in:
@@ -42,8 +42,16 @@ Optional properties:
|
||||
- regulator-state-[mem/disk] node has following common properties:
|
||||
- regulator-on-in-suspend: regulator should be on in suspend state.
|
||||
- regulator-off-in-suspend: regulator should be off in suspend state.
|
||||
- regulator-suspend-microvolt: regulator should be set to this voltage
|
||||
in suspend.
|
||||
- regulator-suspend-min-microvolt: minimum voltage may be set in
|
||||
suspend state.
|
||||
- regulator-suspend-max-microvolt: maximum voltage may be set in
|
||||
suspend state.
|
||||
- regulator-suspend-microvolt: the default voltage which regulator
|
||||
would be set in suspend. This property is now deprecated, instead
|
||||
setting voltage for suspend mode via the API which regulator
|
||||
driver provides is recommended.
|
||||
- regulator-changeable-in-suspend: whether the default voltage and
|
||||
the regulator on/off in suspend can be changed in runtime.
|
||||
- regulator-mode: operating mode in the given suspend state.
|
||||
The set of possible operating modes depends on the capabilities of
|
||||
every hardware so the valid modes are documented on each regulator
|
||||
|
||||
+245
-140
File diff suppressed because it is too large
Load Diff
@@ -16,10 +16,25 @@
|
||||
#ifndef __REGULATOR_INTERNAL_H
|
||||
#define __REGULATOR_INTERNAL_H
|
||||
|
||||
#include <linux/suspend.h>
|
||||
|
||||
#define REGULATOR_STATES_NUM (PM_SUSPEND_MAX + 1)
|
||||
|
||||
struct regulator_voltage {
|
||||
int min_uV;
|
||||
int max_uV;
|
||||
};
|
||||
|
||||
/*
|
||||
* struct regulator
|
||||
*
|
||||
* One for each consumer device.
|
||||
* @voltage - a voltage array for each state of runtime, i.e.:
|
||||
* PM_SUSPEND_ON
|
||||
* PM_SUSPEND_TO_IDLE
|
||||
* PM_SUSPEND_STANDBY
|
||||
* PM_SUSPEND_MEM
|
||||
* PM_SUSPEND_MAX
|
||||
*/
|
||||
struct regulator {
|
||||
struct device *dev;
|
||||
@@ -27,14 +42,22 @@ struct regulator {
|
||||
unsigned int always_on:1;
|
||||
unsigned int bypass:1;
|
||||
int uA_load;
|
||||
int min_uV;
|
||||
int max_uV;
|
||||
struct regulator_voltage voltage[REGULATOR_STATES_NUM];
|
||||
const char *supply_name;
|
||||
struct device_attribute dev_attr;
|
||||
struct regulator_dev *rdev;
|
||||
struct dentry *debugfs;
|
||||
};
|
||||
|
||||
extern struct class regulator_class;
|
||||
|
||||
static inline struct regulator_dev *dev_to_rdev(struct device *dev)
|
||||
{
|
||||
return container_of(dev, struct regulator_dev, dev);
|
||||
}
|
||||
|
||||
struct regulator_dev *of_find_regulator_by_node(struct device_node *np);
|
||||
|
||||
#ifdef CONFIG_OF
|
||||
struct regulator_init_data *regulator_of_get_init_data(struct device *dev,
|
||||
const struct regulator_desc *desc,
|
||||
|
||||
@@ -177,14 +177,30 @@ static void of_get_regulation_constraints(struct device_node *np,
|
||||
|
||||
if (of_property_read_bool(suspend_np,
|
||||
"regulator-on-in-suspend"))
|
||||
suspend_state->enabled = true;
|
||||
suspend_state->enabled = ENABLE_IN_SUSPEND;
|
||||
else if (of_property_read_bool(suspend_np,
|
||||
"regulator-off-in-suspend"))
|
||||
suspend_state->disabled = true;
|
||||
suspend_state->enabled = DISABLE_IN_SUSPEND;
|
||||
else
|
||||
suspend_state->enabled = DO_NOTHING_IN_SUSPEND;
|
||||
|
||||
if (!of_property_read_u32(np, "regulator-suspend-min-microvolt",
|
||||
&pval))
|
||||
suspend_state->min_uV = pval;
|
||||
|
||||
if (!of_property_read_u32(np, "regulator-suspend-max-microvolt",
|
||||
&pval))
|
||||
suspend_state->max_uV = pval;
|
||||
|
||||
if (!of_property_read_u32(suspend_np,
|
||||
"regulator-suspend-microvolt", &pval))
|
||||
suspend_state->uV = pval;
|
||||
else /* otherwise use min_uV as default suspend voltage */
|
||||
suspend_state->uV = suspend_state->min_uV;
|
||||
|
||||
if (of_property_read_bool(suspend_np,
|
||||
"regulator-changeable-in-suspend"))
|
||||
suspend_state->changeable = true;
|
||||
|
||||
if (i == PM_SUSPEND_MEM)
|
||||
constraints->initial_state = PM_SUSPEND_MEM;
|
||||
@@ -376,3 +392,17 @@ struct regulator_init_data *regulator_of_get_init_data(struct device *dev,
|
||||
|
||||
return init_data;
|
||||
}
|
||||
|
||||
static int of_node_match(struct device *dev, const void *data)
|
||||
{
|
||||
return dev->of_node == data;
|
||||
}
|
||||
|
||||
struct regulator_dev *of_find_regulator_by_node(struct device_node *np)
|
||||
{
|
||||
struct device *dev;
|
||||
|
||||
dev = class_find_device(®ulator_class, NULL, np, of_node_match);
|
||||
|
||||
return dev ? dev_to_rdev(dev) : NULL;
|
||||
}
|
||||
|
||||
@@ -214,6 +214,8 @@ struct regulator_ops {
|
||||
/* set regulator suspend operating mode (defined in consumer.h) */
|
||||
int (*set_suspend_mode) (struct regulator_dev *, unsigned int mode);
|
||||
|
||||
int (*resume_early)(struct regulator_dev *rdev);
|
||||
|
||||
int (*set_pull_down) (struct regulator_dev *);
|
||||
};
|
||||
|
||||
|
||||
@@ -42,6 +42,16 @@ struct regulator;
|
||||
#define REGULATOR_CHANGE_DRMS 0x10
|
||||
#define REGULATOR_CHANGE_BYPASS 0x20
|
||||
|
||||
/*
|
||||
* operations in suspend mode
|
||||
* DO_NOTHING_IN_SUSPEND - the default value
|
||||
* DISABLE_IN_SUSPEND - turn off regulator in suspend states
|
||||
* ENABLE_IN_SUSPEND - keep regulator on in suspend states
|
||||
*/
|
||||
#define DO_NOTHING_IN_SUSPEND (-1)
|
||||
#define DISABLE_IN_SUSPEND 0
|
||||
#define ENABLE_IN_SUSPEND 1
|
||||
|
||||
/* Regulator active discharge flags */
|
||||
enum regulator_active_discharge {
|
||||
REGULATOR_ACTIVE_DISCHARGE_DEFAULT,
|
||||
@@ -56,16 +66,24 @@ enum regulator_active_discharge {
|
||||
* state. One of enabled or disabled must be set for the
|
||||
* configuration to be applied.
|
||||
*
|
||||
* @uV: Operating voltage during suspend.
|
||||
* @uV: Default operating voltage during suspend, it can be adjusted
|
||||
* among <min_uV, max_uV>.
|
||||
* @min_uV: Minimum suspend voltage may be set.
|
||||
* @max_uV: Maximum suspend voltage may be set.
|
||||
* @mode: Operating mode during suspend.
|
||||
* @enabled: Enabled during suspend.
|
||||
* @disabled: Disabled during suspend.
|
||||
* @enabled: operations during suspend.
|
||||
* - DO_NOTHING_IN_SUSPEND
|
||||
* - DISABLE_IN_SUSPEND
|
||||
* - ENABLE_IN_SUSPEND
|
||||
* @changeable: Is this state can be switched between enabled/disabled,
|
||||
*/
|
||||
struct regulator_state {
|
||||
int uV; /* suspend voltage */
|
||||
unsigned int mode; /* suspend regulator operating mode */
|
||||
int enabled; /* is regulator enabled in this suspend state */
|
||||
int disabled; /* is the regulator disabled in this suspend state */
|
||||
int uV;
|
||||
int min_uV;
|
||||
int max_uV;
|
||||
unsigned int mode;
|
||||
int enabled;
|
||||
bool changeable;
|
||||
};
|
||||
|
||||
/**
|
||||
@@ -225,12 +243,12 @@ struct regulator_init_data {
|
||||
|
||||
#ifdef CONFIG_REGULATOR
|
||||
void regulator_has_full_constraints(void);
|
||||
int regulator_suspend_prepare(suspend_state_t state);
|
||||
int regulator_suspend_finish(void);
|
||||
#else
|
||||
static inline void regulator_has_full_constraints(void)
|
||||
{
|
||||
}
|
||||
#endif
|
||||
|
||||
static inline int regulator_suspend_prepare(suspend_state_t state)
|
||||
{
|
||||
return 0;
|
||||
@@ -239,6 +257,5 @@ static inline int regulator_suspend_finish(void)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
||||
Reference in New Issue
Block a user