Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 312530
b: refs/heads/master
c: 98a175b
h: refs/heads/master
v: v3
  • Loading branch information
Yadwinder Singh Brar authored and Mark Brown committed Jun 11, 2012
1 parent 3c100d7 commit 79b9c96
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 1 deletion.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: ab0d1cbe55014ac65cfc317f8ef2cd5fa4b7d4da
refs/heads/master: 98a175b60f46a80dfa44fb0e0807f2e5a351f35f
24 changes: 24 additions & 0 deletions trunk/drivers/regulator/core.c
Original file line number Diff line number Diff line change
Expand Up @@ -2279,6 +2279,30 @@ int regulator_set_voltage_time(struct regulator *regulator,
}
EXPORT_SYMBOL_GPL(regulator_set_voltage_time);

/**
*regulator_set_voltage_time_sel - get raise/fall time
* @regulator: regulator source
* @old_selector: selector for starting voltage
* @new_selector: selector for target voltage
*
* Provided with the starting and target voltage selectors, this function
* returns time in microseconds required to rise or fall to this new voltage
*
* Drivers providing uV_step in their regulator_desc and ramp_delay in
* regulation_constraints can use this as their set_voltage_time_sel()
* operation.
*/
int regulator_set_voltage_time_sel(struct regulator_dev *rdev,
unsigned int old_selector,
unsigned int new_selector)
{
if (rdev->desc->ramp_delay && rdev->desc->uV_step)
return DIV_ROUND_UP(rdev->desc->uV_step *
abs(new_selector - old_selector),
rdev->desc->ramp_delay) * 1000;
return 0;
}

/**
* regulator_sync_voltage - re-apply last regulator output voltage
* @regulator: regulator source
Expand Down
5 changes: 5 additions & 0 deletions trunk/include/linux/regulator/driver.h
Original file line number Diff line number Diff line change
Expand Up @@ -170,6 +170,7 @@ enum regulator_type {
*
* @min_uV: Voltage given by the lowest selector (if linear mapping)
* @uV_step: Voltage increase with each selector (if linear mapping)
* @ramp_delay: Time to settle down after voltage change (unit: mV/us)
* @volt_table: Voltage mapping table (if table based mapping)
*
* @vsel_reg: Register for selector when using regulator_regmap_X_voltage_
Expand All @@ -189,6 +190,7 @@ struct regulator_desc {

unsigned int min_uV;
unsigned int uV_step;
unsigned int ramp_delay;

const unsigned int *volt_table;

Expand Down Expand Up @@ -285,6 +287,9 @@ int regulator_set_voltage_sel_regmap(struct regulator_dev *rdev, unsigned sel);
int regulator_is_enabled_regmap(struct regulator_dev *rdev);
int regulator_enable_regmap(struct regulator_dev *rdev);
int regulator_disable_regmap(struct regulator_dev *rdev);
int regulator_set_voltage_time_sel(struct regulator_dev *rdev,
unsigned int old_selector,
unsigned int new_selector);

void *regulator_get_init_drvdata(struct regulator_init_data *reg_init_data);

Expand Down

0 comments on commit 79b9c96

Please sign in to comment.