regulator: rtq2208: Add fixed LDO VOUT property and check that matches the constraints

A fixed LDO VOUT property has been added to specify the fixed_uV of the regulator_desc.
Additionally, a check has been included in this version
to ensure that the fixed_uV matches the constraints.

Signed-off-by: Alina Yu <alina_yu@richtek.com>
Link: https://msgid.link/r/39357ff9e6e5f3dec5a6f7f833a3591c0defc63a.1716870419.git.alina_yu@richtek.com
Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
Alina Yu 2024-05-28 14:01:15 +08:00 committed by Mark Brown
parent 74259990b5
commit af1296d15d
No known key found for this signature in database
GPG Key ID: 24D68B725D5487D0

View File

@ -350,6 +350,7 @@ static int rtq2208_of_get_ldo_dvs_ability(struct device *dev)
struct of_regulator_match *match;
struct regulator_desc *desc;
struct regulator_init_data *init_data;
u32 fixed_uV;
int ret, i;
if (!dev->of_node)
@ -374,9 +375,15 @@ static int rtq2208_of_get_ldo_dvs_ability(struct device *dev)
if (!init_data || !desc)
continue;
if (init_data->constraints.min_uV == init_data->constraints.max_uV) {
desc->fixed_uV = init_data->constraints.min_uV;
/* specify working fixed voltage if the propery exists */
ret = of_property_read_u32(match->of_node, "richtek,fixed-microvolt", &fixed_uV);
if (!ret) {
if (fixed_uV != init_data->constraints.min_uV ||
fixed_uV != init_data->constraints.max_uV)
return -EINVAL;
desc->n_voltages = 1;
desc->fixed_uV = fixed_uV;
desc->fixed_uV = init_data->constraints.min_uV;
desc->ops = &rtq2208_regulator_ldo_fix_ops;
} else {