Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 302263
b: refs/heads/master
c: 1f904fd
h: refs/heads/master
i:
  302261: e48422b
  302259: ba3a0b3
  302255: a165357
v: v3
  • Loading branch information
Axel Lin authored and Mark Brown committed May 9, 2012
1 parent 76b7dad commit e784d42
Show file tree
Hide file tree
Showing 2 changed files with 10 additions and 26 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 5d0526eade515d29769c46bc522055fa17cc536e
refs/heads/master: 1f904fd1cdbda0930f667ad6a1b304d3e8f8334f
34 changes: 9 additions & 25 deletions trunk/drivers/regulator/tps65910-regulator.c
Original file line number Diff line number Diff line change
Expand Up @@ -620,10 +620,10 @@ static int tps65910_get_voltage_dcdc_sel(struct regulator_dev *dev)
return -EINVAL;
}

static int tps65910_get_voltage(struct regulator_dev *dev)
static int tps65910_get_voltage_sel(struct regulator_dev *dev)
{
struct tps65910_reg *pmic = rdev_get_drvdata(dev);
int reg, value, id = rdev_get_id(dev), voltage = 0;
int reg, value, id = rdev_get_id(dev);

reg = pmic->get_ctrl_reg(id);
if (reg < 0)
Expand All @@ -650,20 +650,18 @@ static int tps65910_get_voltage(struct regulator_dev *dev)
return -EINVAL;
}

voltage = pmic->info[id]->voltage_table[value] * 1000;

return voltage;
return value;
}

static int tps65910_get_voltage_vdd3(struct regulator_dev *dev)
{
return 5 * 1000 * 1000;
}

static int tps65911_get_voltage(struct regulator_dev *dev)
static int tps65911_get_voltage_sel(struct regulator_dev *dev)
{
struct tps65910_reg *pmic = rdev_get_drvdata(dev);
int step_mv, id = rdev_get_id(dev);
int id = rdev_get_id(dev);
u8 value, reg;

reg = pmic->get_ctrl_reg(id);
Expand All @@ -676,13 +674,6 @@ static int tps65911_get_voltage(struct regulator_dev *dev)
case TPS65911_REG_LDO4:
value &= LDO1_SEL_MASK;
value >>= LDO_SEL_SHIFT;
/* The first 5 values of the selector correspond to 1V */
if (value < 5)
value = 0;
else
value -= 4;

step_mv = 50;
break;
case TPS65911_REG_LDO3:
case TPS65911_REG_LDO5:
Expand All @@ -691,23 +682,16 @@ static int tps65911_get_voltage(struct regulator_dev *dev)
case TPS65911_REG_LDO8:
value &= LDO3_SEL_MASK;
value >>= LDO_SEL_SHIFT;
/* The first 3 values of the selector correspond to 1V */
if (value < 3)
value = 0;
else
value -= 2;

step_mv = 100;
break;
case TPS65910_REG_VIO:
value &= LDO_SEL_MASK;
value >>= LDO_SEL_SHIFT;
return pmic->info[id]->voltage_table[value] * 1000;
break;
default:
return -EINVAL;
}

return (LDO_MIN_VOLT + value * step_mv) * 1000;
return value;
}

static int tps65910_set_voltage_dcdc_sel(struct regulator_dev *dev,
Expand Down Expand Up @@ -943,7 +927,7 @@ static struct regulator_ops tps65910_ops = {
.enable_time = tps65910_enable_time,
.set_mode = tps65910_set_mode,
.get_mode = tps65910_get_mode,
.get_voltage = tps65910_get_voltage,
.get_voltage_sel = tps65910_get_voltage_sel,
.set_voltage_sel = tps65910_set_voltage_sel,
.list_voltage = tps65910_list_voltage,
};
Expand All @@ -955,7 +939,7 @@ static struct regulator_ops tps65911_ops = {
.enable_time = tps65910_enable_time,
.set_mode = tps65910_set_mode,
.get_mode = tps65910_get_mode,
.get_voltage = tps65911_get_voltage,
.get_voltage_sel = tps65911_get_voltage_sel,
.set_voltage_sel = tps65911_set_voltage_sel,
.list_voltage = tps65911_list_voltage,
};
Expand Down

0 comments on commit e784d42

Please sign in to comment.