[PATCH v4 10/13] iio: dac: ad5686: remove powerdown mask magic number
From: Rodrigo Alencar via B4 Relay
Date: Wed Apr 29 2026 - 09:10:58 EST
From: Rodrigo Alencar <rodrigo.alencar@xxxxxxxxxx>
Define macro AD5686_PD_MSK to hold powerdown mask value.
Signed-off-by: Rodrigo Alencar <rodrigo.alencar@xxxxxxxxxx>
---
drivers/iio/dac/ad5686.c | 16 ++++++++--------
drivers/iio/dac/ad5686.h | 1 +
2 files changed, 9 insertions(+), 8 deletions(-)
diff --git a/drivers/iio/dac/ad5686.c b/drivers/iio/dac/ad5686.c
index 4bcabdbaf1d8..0590716191c1 100644
--- a/drivers/iio/dac/ad5686.c
+++ b/drivers/iio/dac/ad5686.c
@@ -39,7 +39,7 @@ static int ad5686_get_powerdown_mode(struct iio_dev *indio_dev,
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 ((st->pwr_down_mode >> shift) & AD5686_PD_MSK) - 1;
}
static int ad5686_set_powerdown_mode(struct iio_dev *indio_dev,
@@ -51,8 +51,8 @@ static int ad5686_set_powerdown_mode(struct iio_dev *indio_dev,
guard(mutex)(&st->lock);
- st->pwr_down_mode &= ~(0x3 << shift);
- st->pwr_down_mode |= (mode + 1) << shift;
+ st->pwr_down_mode &= ~(AD5686_PD_MSK << shift);
+ st->pwr_down_mode |= ((mode + 1) & AD5686_PD_MSK) << shift;
return 0;
}
@@ -70,7 +70,7 @@ static ssize_t ad5686_read_dac_powerdown(struct iio_dev *indio_dev,
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", !!(st->pwr_down_mask & (AD5686_PD_MSK << shift)));
}
static ssize_t ad5686_write_dac_powerdown(struct iio_dev *indio_dev,
@@ -92,9 +92,9 @@ 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);
+ st->pwr_down_mask |= AD5686_PD_MSK << ad5686_pd_mask_shift(chan);
else
- st->pwr_down_mask &= ~(0x3 << ad5686_pd_mask_shift(chan));
+ st->pwr_down_mask &= ~(AD5686_PD_MSK << ad5686_pd_mask_shift(chan));
switch (st->chip_info->regmap_type) {
case AD5310_REGMAP:
@@ -468,8 +468,8 @@ 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_mask &= ~(AD5686_PD_MSK << shift); /* powered up state */
+ st->pwr_down_mode &= ~(AD5686_PD_MSK << shift);
st->pwr_down_mode |= 0x01 << shift;
}
diff --git a/drivers/iio/dac/ad5686.h b/drivers/iio/dac/ad5686.h
index caadc7403da1..b9eee3ad4dc8 100644
--- a/drivers/iio/dac/ad5686.h
+++ b/drivers/iio/dac/ad5686.h
@@ -47,6 +47,7 @@
#define AD5683_REF_BIT_MSK BIT(12)
#define AD5686_REF_BIT_MSK BIT(0)
+#define AD5686_PD_MSK GENMASK(1, 0)
enum ad5686_regmap_type {
AD5310_REGMAP,
--
2.43.0