提交 f7d37bc3 编写于 作者: C Charles Keepax 提交者: Mark Brown

regulator: helpers: Add regmap set_pull_down helper

Add a helper function regulator_set_pull_down_regmap to allow regmap
based regulators to easily enable pull down.
Signed-off-by: NCharles Keepax <ckeepax@opensource.wolfsonmicro.com>
Signed-off-by: NMark Brown <broonie@kernel.org>
上级 a7a453f5
...@@ -463,6 +463,24 @@ int regulator_set_soft_start_regmap(struct regulator_dev *rdev) ...@@ -463,6 +463,24 @@ int regulator_set_soft_start_regmap(struct regulator_dev *rdev)
} }
EXPORT_SYMBOL_GPL(regulator_set_soft_start_regmap); EXPORT_SYMBOL_GPL(regulator_set_soft_start_regmap);
/**
* regulator_set_pull_down_regmap - Default set_pull_down() using regmap
*
* @rdev: device to operate on.
*/
int regulator_set_pull_down_regmap(struct regulator_dev *rdev)
{
unsigned int val;
val = rdev->desc->pull_down_val_on;
if (!val)
val = rdev->desc->pull_down_mask;
return regmap_update_bits(rdev->regmap, rdev->desc->pull_down_reg,
rdev->desc->pull_down_mask, val);
}
EXPORT_SYMBOL_GPL(regulator_set_pull_down_regmap);
/** /**
* regulator_get_bypass_regmap - Default get_bypass() using regmap * regulator_get_bypass_regmap - Default get_bypass() using regmap
* *
......
...@@ -296,6 +296,10 @@ enum regulator_type { ...@@ -296,6 +296,10 @@ enum regulator_type {
* @soft_start_mask: Mask for control when using regmap set_soft_start * @soft_start_mask: Mask for control when using regmap set_soft_start
* @soft_start_val_on: Enabling value for control when using regmap * @soft_start_val_on: Enabling value for control when using regmap
* set_soft_start * set_soft_start
* @pull_down_reg: Register for control when using regmap set_pull_down
* @pull_down_mask: Mask for control when using regmap set_pull_down
* @pull_down_val_on: Enabling value for control when using regmap
* set_pull_down
* *
* @enable_time: Time taken for initial enable of regulator (in uS). * @enable_time: Time taken for initial enable of regulator (in uS).
* @off_on_delay: guard time (in uS), before re-enabling a regulator * @off_on_delay: guard time (in uS), before re-enabling a regulator
...@@ -352,6 +356,9 @@ struct regulator_desc { ...@@ -352,6 +356,9 @@ struct regulator_desc {
unsigned int soft_start_reg; unsigned int soft_start_reg;
unsigned int soft_start_mask; unsigned int soft_start_mask;
unsigned int soft_start_val_on; unsigned int soft_start_val_on;
unsigned int pull_down_reg;
unsigned int pull_down_mask;
unsigned int pull_down_val_on;
unsigned int enable_time; unsigned int enable_time;
...@@ -484,6 +491,7 @@ int regulator_set_voltage_time_sel(struct regulator_dev *rdev, ...@@ -484,6 +491,7 @@ int regulator_set_voltage_time_sel(struct regulator_dev *rdev,
int regulator_set_bypass_regmap(struct regulator_dev *rdev, bool enable); int regulator_set_bypass_regmap(struct regulator_dev *rdev, bool enable);
int regulator_get_bypass_regmap(struct regulator_dev *rdev, bool *enable); int regulator_get_bypass_regmap(struct regulator_dev *rdev, bool *enable);
int regulator_set_soft_start_regmap(struct regulator_dev *rdev); int regulator_set_soft_start_regmap(struct regulator_dev *rdev);
int regulator_set_pull_down_regmap(struct regulator_dev *rdev);
int regulator_set_active_discharge_regmap(struct regulator_dev *rdev, int regulator_set_active_discharge_regmap(struct regulator_dev *rdev,
bool enable); bool enable);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册