[PATCH v5 09/12] iio: dac: ad5686: add helpers to handle powerdown masks
From: Rodrigo Alencar via B4 Relay
Date: Fri May 01 2026 - 05:18:34 EST
From: Rodrigo Alencar <rodrigo.alencar@xxxxxxxxxx>
Add ad5686_pd_field_set() and ad5686_pd_field_get() helpers to cleanup
powerdown mask control. Define AD5686_PD_* constants, like AD5686_PD_MSK
to hold powerdown mask value for a single channel.
Signed-off-by: Rodrigo Alencar <rodrigo.alencar@xxxxxxxxxx>
---
drivers/iio/dac/ad5686.c | 43 +++++++++++++++++++++++++++----------------
drivers/iio/dac/ad5686.h | 5 +++++
2 files changed, 32 insertions(+), 16 deletions(-)
diff --git a/drivers/iio/dac/ad5686.c b/drivers/iio/dac/ad5686.c
index 4bcabdbaf1d8..4b279d46948d 100644
--- a/drivers/iio/dac/ad5686.c
+++ b/drivers/iio/dac/ad5686.c
@@ -33,26 +33,39 @@ static inline unsigned int ad5686_pd_mask_shift(const struct iio_chan_spec *chan
return __ffs(chan->address) * 2;
}
+static inline void ad5686_pd_field_set(const struct iio_chan_spec *chan,
+ unsigned int *pd, unsigned int val)
+{
+ unsigned int shift = ad5686_pd_mask_shift(chan);
+
+ *pd &= ~(AD5686_PD_MSK << shift);
+ *pd |= (val & AD5686_PD_MSK) << shift;
+}
+
+static inline unsigned int ad5686_pd_field_get(const struct iio_chan_spec *chan,
+ unsigned int pd)
+{
+ unsigned int shift = ad5686_pd_mask_shift(chan);
+
+ return (pd >> shift) & AD5686_PD_MSK;
+}
+
static int ad5686_get_powerdown_mode(struct iio_dev *indio_dev,
const struct iio_chan_spec *chan)
{
- unsigned int shift = ad5686_pd_mask_shift(chan);
struct ad5686_state *st = iio_priv(indio_dev);
- return ((st->pwr_down_mode >> shift) & 0x3) - 1;
+ return ad5686_pd_field_get(chan, st->pwr_down_mode) - 1;
}
static int ad5686_set_powerdown_mode(struct iio_dev *indio_dev,
const struct iio_chan_spec *chan,
unsigned int mode)
{
- unsigned int shift = ad5686_pd_mask_shift(chan);
struct ad5686_state *st = iio_priv(indio_dev);
guard(mutex)(&st->lock);
-
- st->pwr_down_mode &= ~(0x3 << shift);
- st->pwr_down_mode |= (mode + 1) << shift;
+ ad5686_pd_field_set(chan, &st->pwr_down_mode, mode + 1);
return 0;
}
@@ -67,10 +80,10 @@ static const struct iio_enum ad5686_powerdown_mode_enum = {
static ssize_t ad5686_read_dac_powerdown(struct iio_dev *indio_dev,
uintptr_t private, const struct iio_chan_spec *chan, char *buf)
{
- unsigned int shift = ad5686_pd_mask_shift(chan);
struct ad5686_state *st = iio_priv(indio_dev);
- return sysfs_emit(buf, "%d\n", !!(st->pwr_down_mask & (0x3 << shift)));
+ return sysfs_emit(buf, "%d\n",
+ !!ad5686_pd_field_get(chan, st->pwr_down_mask));
}
static ssize_t ad5686_write_dac_powerdown(struct iio_dev *indio_dev,
@@ -91,10 +104,8 @@ static ssize_t ad5686_write_dac_powerdown(struct iio_dev *indio_dev,
guard(mutex)(&st->lock);
- if (readin)
- st->pwr_down_mask |= 0x3 << ad5686_pd_mask_shift(chan);
- else
- st->pwr_down_mask &= ~(0x3 << ad5686_pd_mask_shift(chan));
+ ad5686_pd_field_set(chan, &st->pwr_down_mask,
+ readin ? AD5686_PD_PWR_DOWN : AD5686_PD_PWR_UP);
switch (st->chip_info->regmap_type) {
case AD5310_REGMAP:
@@ -467,10 +478,10 @@ int ad5686_probe(struct device *dev,
/* Set all the power down mode for all channels to 1K pulldown */
for (i = 0; i < st->chip_info->num_channels; i++) {
- shift = ad5686_pd_mask_shift(&st->chip_info->channels[i]);
- st->pwr_down_mask &= ~(0x3 << shift); /* powered up state */
- st->pwr_down_mode &= ~(0x3 << shift);
- st->pwr_down_mode |= 0x01 << shift;
+ ad5686_pd_field_set(&st->chip_info->channels[i],
+ &st->pwr_down_mask, AD5686_PD_PWR_UP);
+ ad5686_pd_field_set(&st->chip_info->channels[i],
+ &st->pwr_down_mode, AD5686_PD_1K_TO_GND);
}
indio_dev->name = name;
diff --git a/drivers/iio/dac/ad5686.h b/drivers/iio/dac/ad5686.h
index caadc7403da1..6b7142fbade2 100644
--- a/drivers/iio/dac/ad5686.h
+++ b/drivers/iio/dac/ad5686.h
@@ -47,6 +47,11 @@
#define AD5683_REF_BIT_MSK BIT(12)
#define AD5686_REF_BIT_MSK BIT(0)
+#define AD5686_PD_MSK GENMASK(1, 0)
+
+#define AD5686_PD_1K_TO_GND 0x1
+#define AD5686_PD_PWR_UP 0x0
+#define AD5686_PD_PWR_DOWN AD5686_PD_MSK
enum ad5686_regmap_type {
AD5310_REGMAP,
--
2.43.0