Skip to content

Commit cccde4c

Browse files
machschmittjic23
authored andcommitted
iio: adc: ad4170-4: Add support for calibration gain
Add support for ADC calibration gain configuration. Signed-off-by: Marcelo Schmitt <marcelo.schmitt@analog.com> Link: https://patch.msgid.link/ea8d07cad9b7b6106f0b5664c403ed080b362a6b.1751895245.git.marcelo.schmitt@analog.com Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
1 parent 2ff7552 commit cccde4c

File tree

1 file changed

+20
-0
lines changed

1 file changed

+20
-0
lines changed

drivers/iio/adc/ad4170-4.c

Lines changed: 20 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -626,6 +626,7 @@ static const struct iio_chan_spec ad4170_channel_template = {
626626
.differential = 1,
627627
.info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
628628
BIT(IIO_CHAN_INFO_SCALE) |
629+
BIT(IIO_CHAN_INFO_CALIBSCALE) |
629630
BIT(IIO_CHAN_INFO_OFFSET),
630631
.info_mask_separate_available = BIT(IIO_CHAN_INFO_SCALE),
631632
.scan_type = {
@@ -948,6 +949,9 @@ static int ad4170_read_raw(struct iio_dev *indio_dev,
948949
pga = FIELD_GET(AD4170_AFE_PGA_GAIN_MSK, setup->afe);
949950
*val = chan_info->offset_tbl[pga];
950951
return IIO_VAL_INT;
952+
case IIO_CHAN_INFO_CALIBSCALE:
953+
*val = setup->gain;
954+
return IIO_VAL_INT;
951955
default:
952956
return -EINVAL;
953957
}
@@ -1062,6 +1066,18 @@ static int ad4170_set_pga(struct ad4170_state *st,
10621066
return ad4170_write_channel_setup(st, chan->address, false);
10631067
}
10641068

1069+
static int ad4170_set_calib_gain(struct ad4170_state *st,
1070+
struct iio_chan_spec const *chan, int val)
1071+
{
1072+
struct ad4170_chan_info *chan_info = &st->chan_infos[chan->address];
1073+
struct ad4170_setup *setup = &chan_info->setup;
1074+
1075+
guard(mutex)(&st->lock);
1076+
setup->gain = val;
1077+
1078+
return ad4170_write_channel_setup(st, chan->address, false);
1079+
}
1080+
10651081
static int __ad4170_write_raw(struct iio_dev *indio_dev,
10661082
struct iio_chan_spec const *chan, int val,
10671083
int val2, long info)
@@ -1071,6 +1087,8 @@ static int __ad4170_write_raw(struct iio_dev *indio_dev,
10711087
switch (info) {
10721088
case IIO_CHAN_INFO_SCALE:
10731089
return ad4170_set_pga(st, chan, val, val2);
1090+
case IIO_CHAN_INFO_CALIBSCALE:
1091+
return ad4170_set_calib_gain(st, chan, val);
10741092
default:
10751093
return -EINVAL;
10761094
}
@@ -1097,6 +1115,8 @@ static int ad4170_write_raw_get_fmt(struct iio_dev *indio_dev,
10971115
switch (info) {
10981116
case IIO_CHAN_INFO_SCALE:
10991117
return IIO_VAL_INT_PLUS_NANO;
1118+
case IIO_CHAN_INFO_CALIBSCALE:
1119+
return IIO_VAL_INT;
11001120
default:
11011121
return -EINVAL;
11021122
}

0 commit comments

Comments
 (0)