mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-01 10:43:43 +00:00
iio: adc: ad7380: use devm_regulator_get_enable_read_voltage()
Use devm_regulator_get_enable_read_voltage() to simplify the code. Reviewed-by: Nuno Sa <nuno.sa@analog.com> Reviewed-by: David Lechner <dlechner@baylibre.com> Signed-off-by: Julien Stephan <jstephan@baylibre.com> Link: https://patch.msgid.link/20241022-ad7380-fix-supplies-v3-2-f0cefe1b7fa6@baylibre.com Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
This commit is contained in:
parent
fbe5956e88
commit
2ac6b2e823
@ -956,7 +956,7 @@ static const struct iio_info ad7380_info = {
|
||||
.debugfs_reg_access = &ad7380_debugfs_reg_access,
|
||||
};
|
||||
|
||||
static int ad7380_init(struct ad7380_state *st, struct regulator *vref)
|
||||
static int ad7380_init(struct ad7380_state *st, bool external_ref_en)
|
||||
{
|
||||
int ret;
|
||||
|
||||
@ -968,13 +968,13 @@ static int ad7380_init(struct ad7380_state *st, struct regulator *vref)
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
|
||||
/* select internal or external reference voltage */
|
||||
ret = regmap_update_bits(st->regmap, AD7380_REG_ADDR_CONFIG1,
|
||||
AD7380_CONFIG1_REFSEL,
|
||||
FIELD_PREP(AD7380_CONFIG1_REFSEL,
|
||||
vref ? 1 : 0));
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
if (external_ref_en) {
|
||||
/* select external reference voltage */
|
||||
ret = regmap_set_bits(st->regmap, AD7380_REG_ADDR_CONFIG1,
|
||||
AD7380_CONFIG1_REFSEL);
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
}
|
||||
|
||||
/* This is the default value after reset. */
|
||||
st->oversampling_ratio = 1;
|
||||
@ -987,16 +987,11 @@ static int ad7380_init(struct ad7380_state *st, struct regulator *vref)
|
||||
FIELD_PREP(AD7380_CONFIG2_SDO, 1));
|
||||
}
|
||||
|
||||
static void ad7380_regulator_disable(void *p)
|
||||
{
|
||||
regulator_disable(p);
|
||||
}
|
||||
|
||||
static int ad7380_probe(struct spi_device *spi)
|
||||
{
|
||||
struct iio_dev *indio_dev;
|
||||
struct ad7380_state *st;
|
||||
struct regulator *vref;
|
||||
bool external_ref_en;
|
||||
int ret, i;
|
||||
|
||||
indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st));
|
||||
@ -1009,37 +1004,17 @@ static int ad7380_probe(struct spi_device *spi)
|
||||
if (!st->chip_info)
|
||||
return dev_err_probe(&spi->dev, -EINVAL, "missing match data\n");
|
||||
|
||||
vref = devm_regulator_get_optional(&spi->dev, "refio");
|
||||
if (IS_ERR(vref)) {
|
||||
if (PTR_ERR(vref) != -ENODEV)
|
||||
return dev_err_probe(&spi->dev, PTR_ERR(vref),
|
||||
"Failed to get refio regulator\n");
|
||||
|
||||
vref = NULL;
|
||||
}
|
||||
|
||||
/*
|
||||
* If there is no REFIO supply, then it means that we are using
|
||||
* the internal 2.5V reference, otherwise REFIO is reference voltage.
|
||||
*/
|
||||
if (vref) {
|
||||
ret = regulator_enable(vref);
|
||||
if (ret)
|
||||
return ret;
|
||||
ret = devm_regulator_get_enable_read_voltage(&spi->dev, "refio");
|
||||
if (ret < 0 && ret != -ENODEV)
|
||||
return dev_err_probe(&spi->dev, ret,
|
||||
"Failed to get refio regulator\n");
|
||||
|
||||
ret = devm_add_action_or_reset(&spi->dev,
|
||||
ad7380_regulator_disable, vref);
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
ret = regulator_get_voltage(vref);
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
|
||||
st->vref_mv = ret / 1000;
|
||||
} else {
|
||||
st->vref_mv = AD7380_INTERNAL_REF_MV;
|
||||
}
|
||||
external_ref_en = ret != -ENODEV;
|
||||
st->vref_mv = external_ref_en ? ret / 1000 : AD7380_INTERNAL_REF_MV;
|
||||
|
||||
if (st->chip_info->num_vcm_supplies > ARRAY_SIZE(st->vcm_mv))
|
||||
return dev_err_probe(&spi->dev, -EINVAL,
|
||||
@ -1050,27 +1025,13 @@ static int ad7380_probe(struct spi_device *spi)
|
||||
* input pin.
|
||||
*/
|
||||
for (i = 0; i < st->chip_info->num_vcm_supplies; i++) {
|
||||
struct regulator *vcm;
|
||||
const char *vcm = st->chip_info->vcm_supplies[i];
|
||||
|
||||
vcm = devm_regulator_get(&spi->dev,
|
||||
st->chip_info->vcm_supplies[i]);
|
||||
if (IS_ERR(vcm))
|
||||
return dev_err_probe(&spi->dev, PTR_ERR(vcm),
|
||||
"Failed to get %s regulator\n",
|
||||
st->chip_info->vcm_supplies[i]);
|
||||
|
||||
ret = regulator_enable(vcm);
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
ret = devm_add_action_or_reset(&spi->dev,
|
||||
ad7380_regulator_disable, vcm);
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
ret = regulator_get_voltage(vcm);
|
||||
ret = devm_regulator_get_enable_read_voltage(&spi->dev, vcm);
|
||||
if (ret < 0)
|
||||
return ret;
|
||||
return dev_err_probe(&spi->dev, ret,
|
||||
"Failed to get %s regulator\n",
|
||||
vcm);
|
||||
|
||||
st->vcm_mv[i] = ret / 1000;
|
||||
}
|
||||
@ -1135,7 +1096,7 @@ static int ad7380_probe(struct spi_device *spi)
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
ret = ad7380_init(st, vref);
|
||||
ret = ad7380_init(st, external_ref_en);
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user