mirror of
https://github.com/nxp-imx/linux-imx.git
synced 2025-07-12 20:35:23 +02:00
Revert "regulator: pickable ranges: don't always cache vsel"
This reverts commitf46695d3b0
which is commitf4f4276f98
upstream. It breaks the Android kernel abi and can be brought back in the future in an abi-safe way if it is really needed. Bug: 161946584 Change-Id: If6484a62f29100de93360cb5aa6f9ada2feeb637 Signed-off-by: Greg Kroah-Hartman <gregkh@google.com>
This commit is contained in:
parent
0e90f8b654
commit
6ad7f6ea6a
|
@ -161,32 +161,6 @@ int regulator_get_voltage_sel_pickable_regmap(struct regulator_dev *rdev)
|
|||
}
|
||||
EXPORT_SYMBOL_GPL(regulator_get_voltage_sel_pickable_regmap);
|
||||
|
||||
static int write_separate_vsel_and_range(struct regulator_dev *rdev,
|
||||
unsigned int sel, unsigned int range)
|
||||
{
|
||||
bool range_updated;
|
||||
int ret;
|
||||
|
||||
ret = regmap_update_bits_base(rdev->regmap, rdev->desc->vsel_range_reg,
|
||||
rdev->desc->vsel_range_mask,
|
||||
range, &range_updated, false, false);
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
/*
|
||||
* Some PMICs treat the vsel_reg same as apply-bit. Force it to be
|
||||
* written if the range changed, even if the old selector was same as
|
||||
* the new one
|
||||
*/
|
||||
if (rdev->desc->range_applied_by_vsel && range_updated)
|
||||
return regmap_write_bits(rdev->regmap,
|
||||
rdev->desc->vsel_reg,
|
||||
rdev->desc->vsel_mask, sel);
|
||||
|
||||
return regmap_update_bits(rdev->regmap, rdev->desc->vsel_reg,
|
||||
rdev->desc->vsel_mask, sel);
|
||||
}
|
||||
|
||||
/**
|
||||
* regulator_set_voltage_sel_pickable_regmap - pickable range set_voltage_sel
|
||||
*
|
||||
|
@ -225,12 +199,21 @@ int regulator_set_voltage_sel_pickable_regmap(struct regulator_dev *rdev,
|
|||
range = rdev->desc->linear_range_selectors_bitfield[i];
|
||||
range <<= ffs(rdev->desc->vsel_range_mask) - 1;
|
||||
|
||||
if (rdev->desc->vsel_reg == rdev->desc->vsel_range_reg)
|
||||
ret = regmap_update_bits(rdev->regmap, rdev->desc->vsel_reg,
|
||||
if (rdev->desc->vsel_reg == rdev->desc->vsel_range_reg) {
|
||||
ret = regmap_update_bits(rdev->regmap,
|
||||
rdev->desc->vsel_reg,
|
||||
rdev->desc->vsel_range_mask |
|
||||
rdev->desc->vsel_mask, sel | range);
|
||||
else
|
||||
ret = write_separate_vsel_and_range(rdev, sel, range);
|
||||
} else {
|
||||
ret = regmap_update_bits(rdev->regmap,
|
||||
rdev->desc->vsel_range_reg,
|
||||
rdev->desc->vsel_range_mask, range);
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
ret = regmap_update_bits(rdev->regmap, rdev->desc->vsel_reg,
|
||||
rdev->desc->vsel_mask, sel);
|
||||
}
|
||||
|
||||
if (ret)
|
||||
return ret;
|
||||
|
|
|
@ -307,8 +307,6 @@ enum regulator_type {
|
|||
* @vsel_range_reg: Register for range selector when using pickable ranges
|
||||
* and ``regulator_map_*_voltage_*_pickable`` functions.
|
||||
* @vsel_range_mask: Mask for register bitfield used for range selector
|
||||
* @range_applied_by_vsel: A flag to indicate that changes to vsel_range_reg
|
||||
* are only effective after vsel_reg is written
|
||||
* @vsel_reg: Register for selector when using ``regulator_map_*_voltage_*``
|
||||
* @vsel_mask: Mask for register bitfield used for selector
|
||||
* @vsel_step: Specify the resolution of selector stepping when setting
|
||||
|
@ -399,7 +397,6 @@ struct regulator_desc {
|
|||
|
||||
unsigned int vsel_range_reg;
|
||||
unsigned int vsel_range_mask;
|
||||
bool range_applied_by_vsel;
|
||||
unsigned int vsel_reg;
|
||||
unsigned int vsel_mask;
|
||||
unsigned int vsel_step;
|
||||
|
|
Loading…
Reference in New Issue
Block a user