xref: /linux/drivers/iio/adc/ad7191.c (revision 4f9786035f9e519db41375818e1d0b5f20da2f10)
1*2e3ae10cSAlisa-Dariana Roman // SPDX-License-Identifier: GPL-2.0-only
2*2e3ae10cSAlisa-Dariana Roman /*
3*2e3ae10cSAlisa-Dariana Roman  * AD7191 ADC driver
4*2e3ae10cSAlisa-Dariana Roman  *
5*2e3ae10cSAlisa-Dariana Roman  * Copyright 2025 Analog Devices Inc.
6*2e3ae10cSAlisa-Dariana Roman  */
7*2e3ae10cSAlisa-Dariana Roman 
8*2e3ae10cSAlisa-Dariana Roman #include <linux/bitfield.h>
9*2e3ae10cSAlisa-Dariana Roman #include <linux/clk.h>
10*2e3ae10cSAlisa-Dariana Roman #include <linux/device.h>
11*2e3ae10cSAlisa-Dariana Roman #include <linux/err.h>
12*2e3ae10cSAlisa-Dariana Roman #include <linux/gpio/consumer.h>
13*2e3ae10cSAlisa-Dariana Roman #include <linux/interrupt.h>
14*2e3ae10cSAlisa-Dariana Roman #include <linux/mod_devicetable.h>
15*2e3ae10cSAlisa-Dariana Roman #include <linux/mutex.h>
16*2e3ae10cSAlisa-Dariana Roman #include <linux/property.h>
17*2e3ae10cSAlisa-Dariana Roman #include <linux/regulator/consumer.h>
18*2e3ae10cSAlisa-Dariana Roman #include <linux/spi/spi.h>
19*2e3ae10cSAlisa-Dariana Roman #include <linux/types.h>
20*2e3ae10cSAlisa-Dariana Roman #include <linux/units.h>
21*2e3ae10cSAlisa-Dariana Roman 
22*2e3ae10cSAlisa-Dariana Roman #include <linux/iio/adc/ad_sigma_delta.h>
23*2e3ae10cSAlisa-Dariana Roman #include <linux/iio/iio.h>
24*2e3ae10cSAlisa-Dariana Roman 
25*2e3ae10cSAlisa-Dariana Roman #define ad_sigma_delta_to_ad7191(sigmad)	\
26*2e3ae10cSAlisa-Dariana Roman 	container_of((sigmad), struct ad7191_state, sd)
27*2e3ae10cSAlisa-Dariana Roman 
28*2e3ae10cSAlisa-Dariana Roman #define AD7191_TEMP_CODES_PER_DEGREE	2815
29*2e3ae10cSAlisa-Dariana Roman 
30*2e3ae10cSAlisa-Dariana Roman #define AD7191_CHAN_MASK		BIT(0)
31*2e3ae10cSAlisa-Dariana Roman #define AD7191_TEMP_MASK		BIT(1)
32*2e3ae10cSAlisa-Dariana Roman 
33*2e3ae10cSAlisa-Dariana Roman enum ad7191_channel {
34*2e3ae10cSAlisa-Dariana Roman 	AD7191_CH_AIN1_AIN2,
35*2e3ae10cSAlisa-Dariana Roman 	AD7191_CH_AIN3_AIN4,
36*2e3ae10cSAlisa-Dariana Roman 	AD7191_CH_TEMP,
37*2e3ae10cSAlisa-Dariana Roman };
38*2e3ae10cSAlisa-Dariana Roman 
39*2e3ae10cSAlisa-Dariana Roman /*
40*2e3ae10cSAlisa-Dariana Roman  * NOTE:
41*2e3ae10cSAlisa-Dariana Roman  * The AD7191 features a dual-use data out ready DOUT/RDY output.
42*2e3ae10cSAlisa-Dariana Roman  * In order to avoid contentions on the SPI bus, it's therefore necessary
43*2e3ae10cSAlisa-Dariana Roman  * to use SPI bus locking.
44*2e3ae10cSAlisa-Dariana Roman  *
45*2e3ae10cSAlisa-Dariana Roman  * The DOUT/RDY output must also be wired to an interrupt-capable GPIO.
46*2e3ae10cSAlisa-Dariana Roman  *
47*2e3ae10cSAlisa-Dariana Roman  * The SPI controller's chip select must be connected to the PDOWN pin
48*2e3ae10cSAlisa-Dariana Roman  * of the ADC. When CS (PDOWN) is high, it powers down the device and
49*2e3ae10cSAlisa-Dariana Roman  * resets the internal circuitry.
50*2e3ae10cSAlisa-Dariana Roman  */
51*2e3ae10cSAlisa-Dariana Roman 
52*2e3ae10cSAlisa-Dariana Roman struct ad7191_state {
53*2e3ae10cSAlisa-Dariana Roman 	struct ad_sigma_delta		sd;
54*2e3ae10cSAlisa-Dariana Roman 	struct mutex			lock; /* Protect device state */
55*2e3ae10cSAlisa-Dariana Roman 
56*2e3ae10cSAlisa-Dariana Roman 	struct gpio_descs		*odr_gpios;
57*2e3ae10cSAlisa-Dariana Roman 	struct gpio_descs		*pga_gpios;
58*2e3ae10cSAlisa-Dariana Roman 	struct gpio_desc		*temp_gpio;
59*2e3ae10cSAlisa-Dariana Roman 	struct gpio_desc		*chan_gpio;
60*2e3ae10cSAlisa-Dariana Roman 
61*2e3ae10cSAlisa-Dariana Roman 	u16				int_vref_mv;
62*2e3ae10cSAlisa-Dariana Roman 	const u32			(*scale_avail)[2];
63*2e3ae10cSAlisa-Dariana Roman 	size_t				scale_avail_size;
64*2e3ae10cSAlisa-Dariana Roman 	u32				scale_index;
65*2e3ae10cSAlisa-Dariana Roman 	const u32			*samp_freq_avail;
66*2e3ae10cSAlisa-Dariana Roman 	size_t				samp_freq_avail_size;
67*2e3ae10cSAlisa-Dariana Roman 	u32				samp_freq_index;
68*2e3ae10cSAlisa-Dariana Roman 
69*2e3ae10cSAlisa-Dariana Roman 	struct clk			*mclk;
70*2e3ae10cSAlisa-Dariana Roman };
71*2e3ae10cSAlisa-Dariana Roman 
72*2e3ae10cSAlisa-Dariana Roman static int ad7191_set_channel(struct ad_sigma_delta *sd, unsigned int address)
73*2e3ae10cSAlisa-Dariana Roman {
74*2e3ae10cSAlisa-Dariana Roman 	struct ad7191_state *st = ad_sigma_delta_to_ad7191(sd);
75*2e3ae10cSAlisa-Dariana Roman 	u8 temp_gpio_val, chan_gpio_val;
76*2e3ae10cSAlisa-Dariana Roman 
77*2e3ae10cSAlisa-Dariana Roman 	if (!FIELD_FIT(AD7191_CHAN_MASK | AD7191_TEMP_MASK, address))
78*2e3ae10cSAlisa-Dariana Roman 		return -EINVAL;
79*2e3ae10cSAlisa-Dariana Roman 
80*2e3ae10cSAlisa-Dariana Roman 	chan_gpio_val = FIELD_GET(AD7191_CHAN_MASK, address);
81*2e3ae10cSAlisa-Dariana Roman 	temp_gpio_val = FIELD_GET(AD7191_TEMP_MASK, address);
82*2e3ae10cSAlisa-Dariana Roman 
83*2e3ae10cSAlisa-Dariana Roman 	gpiod_set_value(st->chan_gpio, chan_gpio_val);
84*2e3ae10cSAlisa-Dariana Roman 	gpiod_set_value(st->temp_gpio, temp_gpio_val);
85*2e3ae10cSAlisa-Dariana Roman 
86*2e3ae10cSAlisa-Dariana Roman 	return 0;
87*2e3ae10cSAlisa-Dariana Roman }
88*2e3ae10cSAlisa-Dariana Roman 
89*2e3ae10cSAlisa-Dariana Roman static int ad7191_set_cs(struct ad_sigma_delta *sigma_delta, int assert)
90*2e3ae10cSAlisa-Dariana Roman {
91*2e3ae10cSAlisa-Dariana Roman 	struct spi_transfer t = {
92*2e3ae10cSAlisa-Dariana Roman 		.len = 0,
93*2e3ae10cSAlisa-Dariana Roman 		.cs_change = assert,
94*2e3ae10cSAlisa-Dariana Roman 	};
95*2e3ae10cSAlisa-Dariana Roman 	struct spi_message m;
96*2e3ae10cSAlisa-Dariana Roman 
97*2e3ae10cSAlisa-Dariana Roman 	spi_message_init_with_transfers(&m, &t, 1);
98*2e3ae10cSAlisa-Dariana Roman 
99*2e3ae10cSAlisa-Dariana Roman 	return spi_sync_locked(sigma_delta->spi, &m);
100*2e3ae10cSAlisa-Dariana Roman }
101*2e3ae10cSAlisa-Dariana Roman 
102*2e3ae10cSAlisa-Dariana Roman static int ad7191_set_mode(struct ad_sigma_delta *sd,
103*2e3ae10cSAlisa-Dariana Roman 			   enum ad_sigma_delta_mode mode)
104*2e3ae10cSAlisa-Dariana Roman {
105*2e3ae10cSAlisa-Dariana Roman 	struct ad7191_state *st = ad_sigma_delta_to_ad7191(sd);
106*2e3ae10cSAlisa-Dariana Roman 
107*2e3ae10cSAlisa-Dariana Roman 	switch (mode) {
108*2e3ae10cSAlisa-Dariana Roman 	case AD_SD_MODE_CONTINUOUS:
109*2e3ae10cSAlisa-Dariana Roman 	case AD_SD_MODE_SINGLE:
110*2e3ae10cSAlisa-Dariana Roman 		return ad7191_set_cs(&st->sd, 1);
111*2e3ae10cSAlisa-Dariana Roman 	case AD_SD_MODE_IDLE:
112*2e3ae10cSAlisa-Dariana Roman 		return ad7191_set_cs(&st->sd, 0);
113*2e3ae10cSAlisa-Dariana Roman 	default:
114*2e3ae10cSAlisa-Dariana Roman 		return -EINVAL;
115*2e3ae10cSAlisa-Dariana Roman 	}
116*2e3ae10cSAlisa-Dariana Roman }
117*2e3ae10cSAlisa-Dariana Roman 
118*2e3ae10cSAlisa-Dariana Roman static const struct ad_sigma_delta_info ad7191_sigma_delta_info = {
119*2e3ae10cSAlisa-Dariana Roman 	.set_channel = ad7191_set_channel,
120*2e3ae10cSAlisa-Dariana Roman 	.set_mode = ad7191_set_mode,
121*2e3ae10cSAlisa-Dariana Roman 	.has_registers = false,
122*2e3ae10cSAlisa-Dariana Roman };
123*2e3ae10cSAlisa-Dariana Roman 
124*2e3ae10cSAlisa-Dariana Roman static int ad7191_init_regulators(struct iio_dev *indio_dev)
125*2e3ae10cSAlisa-Dariana Roman {
126*2e3ae10cSAlisa-Dariana Roman 	struct ad7191_state *st = iio_priv(indio_dev);
127*2e3ae10cSAlisa-Dariana Roman 	struct device *dev = &st->sd.spi->dev;
128*2e3ae10cSAlisa-Dariana Roman 	int ret;
129*2e3ae10cSAlisa-Dariana Roman 
130*2e3ae10cSAlisa-Dariana Roman 	ret = devm_regulator_get_enable(dev, "avdd");
131*2e3ae10cSAlisa-Dariana Roman 	if (ret)
132*2e3ae10cSAlisa-Dariana Roman 		return dev_err_probe(dev, ret, "Failed to enable specified AVdd supply\n");
133*2e3ae10cSAlisa-Dariana Roman 
134*2e3ae10cSAlisa-Dariana Roman 	ret = devm_regulator_get_enable(dev, "dvdd");
135*2e3ae10cSAlisa-Dariana Roman 	if (ret)
136*2e3ae10cSAlisa-Dariana Roman 		return dev_err_probe(dev, ret, "Failed to enable specified DVdd supply\n");
137*2e3ae10cSAlisa-Dariana Roman 
138*2e3ae10cSAlisa-Dariana Roman 	ret = devm_regulator_get_enable_read_voltage(dev, "vref");
139*2e3ae10cSAlisa-Dariana Roman 	if (ret < 0)
140*2e3ae10cSAlisa-Dariana Roman 		return dev_err_probe(dev, ret, "Failed to get Vref voltage\n");
141*2e3ae10cSAlisa-Dariana Roman 
142*2e3ae10cSAlisa-Dariana Roman 	st->int_vref_mv = ret / 1000;
143*2e3ae10cSAlisa-Dariana Roman 
144*2e3ae10cSAlisa-Dariana Roman 	return 0;
145*2e3ae10cSAlisa-Dariana Roman }
146*2e3ae10cSAlisa-Dariana Roman 
147*2e3ae10cSAlisa-Dariana Roman static int ad7191_config_setup(struct iio_dev *indio_dev)
148*2e3ae10cSAlisa-Dariana Roman {
149*2e3ae10cSAlisa-Dariana Roman 	struct ad7191_state *st = iio_priv(indio_dev);
150*2e3ae10cSAlisa-Dariana Roman 	struct device *dev = &st->sd.spi->dev;
151*2e3ae10cSAlisa-Dariana Roman 	/* Sampling frequencies in Hz, see Table 5 */
152*2e3ae10cSAlisa-Dariana Roman 	static const u32 samp_freq[4] = { 120, 60, 50, 10 };
153*2e3ae10cSAlisa-Dariana Roman 	/* Gain options, see Table 7 */
154*2e3ae10cSAlisa-Dariana Roman 	const u32 gain[4] = { 1, 8, 64, 128 };
155*2e3ae10cSAlisa-Dariana Roman 	static u32 scale_buffer[4][2];
156*2e3ae10cSAlisa-Dariana Roman 	int odr_value, odr_index = 0, pga_value, pga_index = 0, i, ret;
157*2e3ae10cSAlisa-Dariana Roman 	u64 scale_uv;
158*2e3ae10cSAlisa-Dariana Roman 
159*2e3ae10cSAlisa-Dariana Roman 	st->samp_freq_index = 0;
160*2e3ae10cSAlisa-Dariana Roman 	st->scale_index = 0;
161*2e3ae10cSAlisa-Dariana Roman 
162*2e3ae10cSAlisa-Dariana Roman 	ret = device_property_read_u32(dev, "adi,odr-value", &odr_value);
163*2e3ae10cSAlisa-Dariana Roman 	if (ret && ret != -EINVAL)
164*2e3ae10cSAlisa-Dariana Roman 		return dev_err_probe(dev, ret, "Failed to get odr value.\n");
165*2e3ae10cSAlisa-Dariana Roman 
166*2e3ae10cSAlisa-Dariana Roman 	if (ret == -EINVAL) {
167*2e3ae10cSAlisa-Dariana Roman 		st->odr_gpios = devm_gpiod_get_array(dev, "odr", GPIOD_OUT_LOW);
168*2e3ae10cSAlisa-Dariana Roman 		if (IS_ERR(st->odr_gpios))
169*2e3ae10cSAlisa-Dariana Roman 			return dev_err_probe(dev, PTR_ERR(st->odr_gpios),
170*2e3ae10cSAlisa-Dariana Roman 					     "Failed to get odr gpios.\n");
171*2e3ae10cSAlisa-Dariana Roman 
172*2e3ae10cSAlisa-Dariana Roman 		if (st->odr_gpios->ndescs != 2)
173*2e3ae10cSAlisa-Dariana Roman 			return dev_err_probe(dev, -EINVAL, "Expected 2 odr gpio pins.\n");
174*2e3ae10cSAlisa-Dariana Roman 
175*2e3ae10cSAlisa-Dariana Roman 		st->samp_freq_avail = samp_freq;
176*2e3ae10cSAlisa-Dariana Roman 		st->samp_freq_avail_size = ARRAY_SIZE(samp_freq);
177*2e3ae10cSAlisa-Dariana Roman 	} else {
178*2e3ae10cSAlisa-Dariana Roman 		for (i = 0; i < ARRAY_SIZE(samp_freq); i++) {
179*2e3ae10cSAlisa-Dariana Roman 			if (odr_value != samp_freq[i])
180*2e3ae10cSAlisa-Dariana Roman 				continue;
181*2e3ae10cSAlisa-Dariana Roman 			odr_index = i;
182*2e3ae10cSAlisa-Dariana Roman 			break;
183*2e3ae10cSAlisa-Dariana Roman 		}
184*2e3ae10cSAlisa-Dariana Roman 
185*2e3ae10cSAlisa-Dariana Roman 		st->samp_freq_avail = &samp_freq[odr_index];
186*2e3ae10cSAlisa-Dariana Roman 		st->samp_freq_avail_size = 1;
187*2e3ae10cSAlisa-Dariana Roman 
188*2e3ae10cSAlisa-Dariana Roman 		st->odr_gpios = NULL;
189*2e3ae10cSAlisa-Dariana Roman 	}
190*2e3ae10cSAlisa-Dariana Roman 
191*2e3ae10cSAlisa-Dariana Roman 	mutex_lock(&st->lock);
192*2e3ae10cSAlisa-Dariana Roman 
193*2e3ae10cSAlisa-Dariana Roman 	for (i = 0; i < ARRAY_SIZE(scale_buffer); i++) {
194*2e3ae10cSAlisa-Dariana Roman 		scale_uv = ((u64)st->int_vref_mv * NANO) >>
195*2e3ae10cSAlisa-Dariana Roman 			(indio_dev->channels[0].scan_type.realbits - 1);
196*2e3ae10cSAlisa-Dariana Roman 		do_div(scale_uv, gain[i]);
197*2e3ae10cSAlisa-Dariana Roman 		scale_buffer[i][1] = do_div(scale_uv, NANO);
198*2e3ae10cSAlisa-Dariana Roman 		scale_buffer[i][0] = scale_uv;
199*2e3ae10cSAlisa-Dariana Roman 	}
200*2e3ae10cSAlisa-Dariana Roman 
201*2e3ae10cSAlisa-Dariana Roman 	mutex_unlock(&st->lock);
202*2e3ae10cSAlisa-Dariana Roman 
203*2e3ae10cSAlisa-Dariana Roman 	ret = device_property_read_u32(dev, "adi,pga-value", &pga_value);
204*2e3ae10cSAlisa-Dariana Roman 	if (ret && ret != -EINVAL)
205*2e3ae10cSAlisa-Dariana Roman 		return dev_err_probe(dev, ret, "Failed to get pga value.\n");
206*2e3ae10cSAlisa-Dariana Roman 
207*2e3ae10cSAlisa-Dariana Roman 	if (ret == -EINVAL) {
208*2e3ae10cSAlisa-Dariana Roman 		st->pga_gpios = devm_gpiod_get_array(dev, "pga", GPIOD_OUT_LOW);
209*2e3ae10cSAlisa-Dariana Roman 		if (IS_ERR(st->pga_gpios))
210*2e3ae10cSAlisa-Dariana Roman 			return dev_err_probe(dev, PTR_ERR(st->pga_gpios),
211*2e3ae10cSAlisa-Dariana Roman 					     "Failed to get pga gpios.\n");
212*2e3ae10cSAlisa-Dariana Roman 
213*2e3ae10cSAlisa-Dariana Roman 		if (st->pga_gpios->ndescs != 2)
214*2e3ae10cSAlisa-Dariana Roman 			return dev_err_probe(dev, -EINVAL, "Expected 2 pga gpio pins.\n");
215*2e3ae10cSAlisa-Dariana Roman 
216*2e3ae10cSAlisa-Dariana Roman 		st->scale_avail = scale_buffer;
217*2e3ae10cSAlisa-Dariana Roman 		st->scale_avail_size = ARRAY_SIZE(scale_buffer);
218*2e3ae10cSAlisa-Dariana Roman 	} else {
219*2e3ae10cSAlisa-Dariana Roman 		for (i = 0; i < ARRAY_SIZE(gain); i++) {
220*2e3ae10cSAlisa-Dariana Roman 			if (pga_value != gain[i])
221*2e3ae10cSAlisa-Dariana Roman 				continue;
222*2e3ae10cSAlisa-Dariana Roman 			pga_index = i;
223*2e3ae10cSAlisa-Dariana Roman 			break;
224*2e3ae10cSAlisa-Dariana Roman 		}
225*2e3ae10cSAlisa-Dariana Roman 
226*2e3ae10cSAlisa-Dariana Roman 		st->scale_avail = &scale_buffer[pga_index];
227*2e3ae10cSAlisa-Dariana Roman 		st->scale_avail_size = 1;
228*2e3ae10cSAlisa-Dariana Roman 
229*2e3ae10cSAlisa-Dariana Roman 		st->pga_gpios = NULL;
230*2e3ae10cSAlisa-Dariana Roman 	}
231*2e3ae10cSAlisa-Dariana Roman 
232*2e3ae10cSAlisa-Dariana Roman 	st->temp_gpio = devm_gpiod_get(dev, "temp", GPIOD_OUT_LOW);
233*2e3ae10cSAlisa-Dariana Roman 	if (IS_ERR(st->temp_gpio))
234*2e3ae10cSAlisa-Dariana Roman 		return dev_err_probe(dev, PTR_ERR(st->temp_gpio),
235*2e3ae10cSAlisa-Dariana Roman 				     "Failed to get temp gpio.\n");
236*2e3ae10cSAlisa-Dariana Roman 
237*2e3ae10cSAlisa-Dariana Roman 	st->chan_gpio = devm_gpiod_get(dev, "chan", GPIOD_OUT_LOW);
238*2e3ae10cSAlisa-Dariana Roman 	if (IS_ERR(st->chan_gpio))
239*2e3ae10cSAlisa-Dariana Roman 		return dev_err_probe(dev, PTR_ERR(st->chan_gpio),
240*2e3ae10cSAlisa-Dariana Roman 				     "Failed to get chan gpio.\n");
241*2e3ae10cSAlisa-Dariana Roman 
242*2e3ae10cSAlisa-Dariana Roman 	return 0;
243*2e3ae10cSAlisa-Dariana Roman }
244*2e3ae10cSAlisa-Dariana Roman 
245*2e3ae10cSAlisa-Dariana Roman static int ad7191_clock_setup(struct ad7191_state *st)
246*2e3ae10cSAlisa-Dariana Roman {
247*2e3ae10cSAlisa-Dariana Roman 	struct device *dev = &st->sd.spi->dev;
248*2e3ae10cSAlisa-Dariana Roman 
249*2e3ae10cSAlisa-Dariana Roman 	st->mclk = devm_clk_get_optional_enabled(dev, "mclk");
250*2e3ae10cSAlisa-Dariana Roman 	if (IS_ERR(st->mclk))
251*2e3ae10cSAlisa-Dariana Roman 		return dev_err_probe(dev, PTR_ERR(st->mclk),
252*2e3ae10cSAlisa-Dariana Roman 				     "Failed to get mclk.\n");
253*2e3ae10cSAlisa-Dariana Roman 
254*2e3ae10cSAlisa-Dariana Roman 	return 0;
255*2e3ae10cSAlisa-Dariana Roman }
256*2e3ae10cSAlisa-Dariana Roman 
257*2e3ae10cSAlisa-Dariana Roman static int ad7191_setup(struct iio_dev *indio_dev)
258*2e3ae10cSAlisa-Dariana Roman {
259*2e3ae10cSAlisa-Dariana Roman 	struct ad7191_state *st = iio_priv(indio_dev);
260*2e3ae10cSAlisa-Dariana Roman 	int ret;
261*2e3ae10cSAlisa-Dariana Roman 
262*2e3ae10cSAlisa-Dariana Roman 	ret = ad7191_init_regulators(indio_dev);
263*2e3ae10cSAlisa-Dariana Roman 	if (ret)
264*2e3ae10cSAlisa-Dariana Roman 		return ret;
265*2e3ae10cSAlisa-Dariana Roman 
266*2e3ae10cSAlisa-Dariana Roman 	ret = ad7191_config_setup(indio_dev);
267*2e3ae10cSAlisa-Dariana Roman 	if (ret)
268*2e3ae10cSAlisa-Dariana Roman 		return ret;
269*2e3ae10cSAlisa-Dariana Roman 
270*2e3ae10cSAlisa-Dariana Roman 	return ad7191_clock_setup(st);
271*2e3ae10cSAlisa-Dariana Roman }
272*2e3ae10cSAlisa-Dariana Roman 
273*2e3ae10cSAlisa-Dariana Roman static int ad7191_read_raw(struct iio_dev *indio_dev,
274*2e3ae10cSAlisa-Dariana Roman 			   struct iio_chan_spec const *chan, int *val,
275*2e3ae10cSAlisa-Dariana Roman 			   int *val2, long m)
276*2e3ae10cSAlisa-Dariana Roman {
277*2e3ae10cSAlisa-Dariana Roman 	struct ad7191_state *st = iio_priv(indio_dev);
278*2e3ae10cSAlisa-Dariana Roman 
279*2e3ae10cSAlisa-Dariana Roman 	switch (m) {
280*2e3ae10cSAlisa-Dariana Roman 	case IIO_CHAN_INFO_RAW:
281*2e3ae10cSAlisa-Dariana Roman 		return ad_sigma_delta_single_conversion(indio_dev, chan, val);
282*2e3ae10cSAlisa-Dariana Roman 	case IIO_CHAN_INFO_SCALE:
283*2e3ae10cSAlisa-Dariana Roman 		switch (chan->type) {
284*2e3ae10cSAlisa-Dariana Roman 		case IIO_VOLTAGE: {
285*2e3ae10cSAlisa-Dariana Roman 			guard(mutex)(&st->lock);
286*2e3ae10cSAlisa-Dariana Roman 			*val = st->scale_avail[st->scale_index][0];
287*2e3ae10cSAlisa-Dariana Roman 			*val2 = st->scale_avail[st->scale_index][1];
288*2e3ae10cSAlisa-Dariana Roman 			return IIO_VAL_INT_PLUS_NANO;
289*2e3ae10cSAlisa-Dariana Roman 		}
290*2e3ae10cSAlisa-Dariana Roman 		case IIO_TEMP:
291*2e3ae10cSAlisa-Dariana Roman 			*val = 0;
292*2e3ae10cSAlisa-Dariana Roman 			*val2 = NANO / AD7191_TEMP_CODES_PER_DEGREE;
293*2e3ae10cSAlisa-Dariana Roman 			return IIO_VAL_INT_PLUS_NANO;
294*2e3ae10cSAlisa-Dariana Roman 		default:
295*2e3ae10cSAlisa-Dariana Roman 			return -EINVAL;
296*2e3ae10cSAlisa-Dariana Roman 		}
297*2e3ae10cSAlisa-Dariana Roman 	case IIO_CHAN_INFO_OFFSET:
298*2e3ae10cSAlisa-Dariana Roman 		*val = -(1 << (chan->scan_type.realbits - 1));
299*2e3ae10cSAlisa-Dariana Roman 		switch (chan->type) {
300*2e3ae10cSAlisa-Dariana Roman 		case IIO_VOLTAGE:
301*2e3ae10cSAlisa-Dariana Roman 			return IIO_VAL_INT;
302*2e3ae10cSAlisa-Dariana Roman 		case IIO_TEMP:
303*2e3ae10cSAlisa-Dariana Roman 			*val -= 273 * AD7191_TEMP_CODES_PER_DEGREE;
304*2e3ae10cSAlisa-Dariana Roman 			return IIO_VAL_INT;
305*2e3ae10cSAlisa-Dariana Roman 		default:
306*2e3ae10cSAlisa-Dariana Roman 			return -EINVAL;
307*2e3ae10cSAlisa-Dariana Roman 		}
308*2e3ae10cSAlisa-Dariana Roman 	case IIO_CHAN_INFO_SAMP_FREQ:
309*2e3ae10cSAlisa-Dariana Roman 		*val = st->samp_freq_avail[st->samp_freq_index];
310*2e3ae10cSAlisa-Dariana Roman 		return IIO_VAL_INT;
311*2e3ae10cSAlisa-Dariana Roman 	default:
312*2e3ae10cSAlisa-Dariana Roman 		return -EINVAL;
313*2e3ae10cSAlisa-Dariana Roman 	}
314*2e3ae10cSAlisa-Dariana Roman }
315*2e3ae10cSAlisa-Dariana Roman 
316*2e3ae10cSAlisa-Dariana Roman static int ad7191_set_gain(struct ad7191_state *st, int gain_index)
317*2e3ae10cSAlisa-Dariana Roman {
318*2e3ae10cSAlisa-Dariana Roman 	DECLARE_BITMAP(bitmap, 2) = { };
319*2e3ae10cSAlisa-Dariana Roman 
320*2e3ae10cSAlisa-Dariana Roman 	st->scale_index = gain_index;
321*2e3ae10cSAlisa-Dariana Roman 
322*2e3ae10cSAlisa-Dariana Roman 	bitmap_write(bitmap, gain_index, 0, 2);
323*2e3ae10cSAlisa-Dariana Roman 
324*2e3ae10cSAlisa-Dariana Roman 	return gpiod_multi_set_value_cansleep(st->pga_gpios, bitmap);
325*2e3ae10cSAlisa-Dariana Roman }
326*2e3ae10cSAlisa-Dariana Roman 
327*2e3ae10cSAlisa-Dariana Roman static int ad7191_set_samp_freq(struct ad7191_state *st, int samp_freq_index)
328*2e3ae10cSAlisa-Dariana Roman {
329*2e3ae10cSAlisa-Dariana Roman 	DECLARE_BITMAP(bitmap, 2) = {};
330*2e3ae10cSAlisa-Dariana Roman 
331*2e3ae10cSAlisa-Dariana Roman 	st->samp_freq_index = samp_freq_index;
332*2e3ae10cSAlisa-Dariana Roman 
333*2e3ae10cSAlisa-Dariana Roman 	bitmap_write(bitmap, samp_freq_index, 0, 2);
334*2e3ae10cSAlisa-Dariana Roman 
335*2e3ae10cSAlisa-Dariana Roman 	return gpiod_multi_set_value_cansleep(st->odr_gpios, bitmap);
336*2e3ae10cSAlisa-Dariana Roman }
337*2e3ae10cSAlisa-Dariana Roman 
338*2e3ae10cSAlisa-Dariana Roman static int __ad7191_write_raw(struct ad7191_state *st,
339*2e3ae10cSAlisa-Dariana Roman 			      struct iio_chan_spec const *chan,
340*2e3ae10cSAlisa-Dariana Roman 			      int val, int val2, long mask)
341*2e3ae10cSAlisa-Dariana Roman {
342*2e3ae10cSAlisa-Dariana Roman 	int i;
343*2e3ae10cSAlisa-Dariana Roman 
344*2e3ae10cSAlisa-Dariana Roman 	switch (mask) {
345*2e3ae10cSAlisa-Dariana Roman 	case IIO_CHAN_INFO_SCALE: {
346*2e3ae10cSAlisa-Dariana Roman 		if (!st->pga_gpios)
347*2e3ae10cSAlisa-Dariana Roman 			return -EPERM;
348*2e3ae10cSAlisa-Dariana Roman 		guard(mutex)(&st->lock);
349*2e3ae10cSAlisa-Dariana Roman 		for (i = 0; i < st->scale_avail_size; i++) {
350*2e3ae10cSAlisa-Dariana Roman 			if (val2 == st->scale_avail[i][1])
351*2e3ae10cSAlisa-Dariana Roman 				return ad7191_set_gain(st, i);
352*2e3ae10cSAlisa-Dariana Roman 		}
353*2e3ae10cSAlisa-Dariana Roman 		return -EINVAL;
354*2e3ae10cSAlisa-Dariana Roman 	}
355*2e3ae10cSAlisa-Dariana Roman 	case IIO_CHAN_INFO_SAMP_FREQ: {
356*2e3ae10cSAlisa-Dariana Roman 		if (!st->odr_gpios)
357*2e3ae10cSAlisa-Dariana Roman 			return -EPERM;
358*2e3ae10cSAlisa-Dariana Roman 		guard(mutex)(&st->lock);
359*2e3ae10cSAlisa-Dariana Roman 		for (i = 0; i < st->samp_freq_avail_size; i++) {
360*2e3ae10cSAlisa-Dariana Roman 			if (val == st->samp_freq_avail[i])
361*2e3ae10cSAlisa-Dariana Roman 				return ad7191_set_samp_freq(st, i);
362*2e3ae10cSAlisa-Dariana Roman 		}
363*2e3ae10cSAlisa-Dariana Roman 		return -EINVAL;
364*2e3ae10cSAlisa-Dariana Roman 	}
365*2e3ae10cSAlisa-Dariana Roman 	default:
366*2e3ae10cSAlisa-Dariana Roman 		return -EINVAL;
367*2e3ae10cSAlisa-Dariana Roman 	}
368*2e3ae10cSAlisa-Dariana Roman }
369*2e3ae10cSAlisa-Dariana Roman 
370*2e3ae10cSAlisa-Dariana Roman static int ad7191_write_raw(struct iio_dev *indio_dev,
371*2e3ae10cSAlisa-Dariana Roman 			    struct iio_chan_spec const *chan, int val, int val2,
372*2e3ae10cSAlisa-Dariana Roman 			    long mask)
373*2e3ae10cSAlisa-Dariana Roman {
374*2e3ae10cSAlisa-Dariana Roman 	struct ad7191_state *st = iio_priv(indio_dev);
375*2e3ae10cSAlisa-Dariana Roman 	int ret;
376*2e3ae10cSAlisa-Dariana Roman 
377*2e3ae10cSAlisa-Dariana Roman 	if (!iio_device_claim_direct(indio_dev))
378*2e3ae10cSAlisa-Dariana Roman 		return -EBUSY;
379*2e3ae10cSAlisa-Dariana Roman 
380*2e3ae10cSAlisa-Dariana Roman 	ret = __ad7191_write_raw(st, chan, val, val2, mask);
381*2e3ae10cSAlisa-Dariana Roman 
382*2e3ae10cSAlisa-Dariana Roman 	iio_device_release_direct(indio_dev);
383*2e3ae10cSAlisa-Dariana Roman 
384*2e3ae10cSAlisa-Dariana Roman 	return ret;
385*2e3ae10cSAlisa-Dariana Roman }
386*2e3ae10cSAlisa-Dariana Roman 
387*2e3ae10cSAlisa-Dariana Roman static int ad7191_write_raw_get_fmt(struct iio_dev *indio_dev,
388*2e3ae10cSAlisa-Dariana Roman 				    struct iio_chan_spec const *chan, long mask)
389*2e3ae10cSAlisa-Dariana Roman {
390*2e3ae10cSAlisa-Dariana Roman 	switch (mask) {
391*2e3ae10cSAlisa-Dariana Roman 	case IIO_CHAN_INFO_SCALE:
392*2e3ae10cSAlisa-Dariana Roman 		return IIO_VAL_INT_PLUS_NANO;
393*2e3ae10cSAlisa-Dariana Roman 	case IIO_CHAN_INFO_SAMP_FREQ:
394*2e3ae10cSAlisa-Dariana Roman 		return IIO_VAL_INT;
395*2e3ae10cSAlisa-Dariana Roman 	default:
396*2e3ae10cSAlisa-Dariana Roman 		return -EINVAL;
397*2e3ae10cSAlisa-Dariana Roman 	}
398*2e3ae10cSAlisa-Dariana Roman }
399*2e3ae10cSAlisa-Dariana Roman 
400*2e3ae10cSAlisa-Dariana Roman static int ad7191_read_avail(struct iio_dev *indio_dev,
401*2e3ae10cSAlisa-Dariana Roman 			     struct iio_chan_spec const *chan, const int **vals,
402*2e3ae10cSAlisa-Dariana Roman 			     int *type, int *length, long mask)
403*2e3ae10cSAlisa-Dariana Roman {
404*2e3ae10cSAlisa-Dariana Roman 	struct ad7191_state *st = iio_priv(indio_dev);
405*2e3ae10cSAlisa-Dariana Roman 
406*2e3ae10cSAlisa-Dariana Roman 	switch (mask) {
407*2e3ae10cSAlisa-Dariana Roman 	case IIO_CHAN_INFO_SCALE:
408*2e3ae10cSAlisa-Dariana Roman 		*vals = (int *)st->scale_avail;
409*2e3ae10cSAlisa-Dariana Roman 		*type = IIO_VAL_INT_PLUS_NANO;
410*2e3ae10cSAlisa-Dariana Roman 		*length = st->scale_avail_size * 2;
411*2e3ae10cSAlisa-Dariana Roman 		return IIO_AVAIL_LIST;
412*2e3ae10cSAlisa-Dariana Roman 	case IIO_CHAN_INFO_SAMP_FREQ:
413*2e3ae10cSAlisa-Dariana Roman 		*vals = (int *)st->samp_freq_avail;
414*2e3ae10cSAlisa-Dariana Roman 		*type = IIO_VAL_INT;
415*2e3ae10cSAlisa-Dariana Roman 		*length = st->samp_freq_avail_size;
416*2e3ae10cSAlisa-Dariana Roman 		return IIO_AVAIL_LIST;
417*2e3ae10cSAlisa-Dariana Roman 	}
418*2e3ae10cSAlisa-Dariana Roman 
419*2e3ae10cSAlisa-Dariana Roman 	return -EINVAL;
420*2e3ae10cSAlisa-Dariana Roman }
421*2e3ae10cSAlisa-Dariana Roman 
422*2e3ae10cSAlisa-Dariana Roman static const struct iio_info ad7191_info = {
423*2e3ae10cSAlisa-Dariana Roman 	.read_raw = ad7191_read_raw,
424*2e3ae10cSAlisa-Dariana Roman 	.write_raw = ad7191_write_raw,
425*2e3ae10cSAlisa-Dariana Roman 	.write_raw_get_fmt = ad7191_write_raw_get_fmt,
426*2e3ae10cSAlisa-Dariana Roman 	.read_avail = ad7191_read_avail,
427*2e3ae10cSAlisa-Dariana Roman 	.validate_trigger = ad_sd_validate_trigger,
428*2e3ae10cSAlisa-Dariana Roman };
429*2e3ae10cSAlisa-Dariana Roman 
430*2e3ae10cSAlisa-Dariana Roman static const struct iio_chan_spec ad7191_channels[] = {
431*2e3ae10cSAlisa-Dariana Roman 	{
432*2e3ae10cSAlisa-Dariana Roman 		.type = IIO_TEMP,
433*2e3ae10cSAlisa-Dariana Roman 		.address = AD7191_CH_TEMP,
434*2e3ae10cSAlisa-Dariana Roman 		.info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
435*2e3ae10cSAlisa-Dariana Roman 				      BIT(IIO_CHAN_INFO_OFFSET) |
436*2e3ae10cSAlisa-Dariana Roman 				      BIT(IIO_CHAN_INFO_SAMP_FREQ),
437*2e3ae10cSAlisa-Dariana Roman 		.info_mask_shared_by_all_available = BIT(IIO_CHAN_INFO_SAMP_FREQ),
438*2e3ae10cSAlisa-Dariana Roman 		.info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE),
439*2e3ae10cSAlisa-Dariana Roman 		.scan_type = {
440*2e3ae10cSAlisa-Dariana Roman 			.sign = 'u',
441*2e3ae10cSAlisa-Dariana Roman 			.realbits = 24,
442*2e3ae10cSAlisa-Dariana Roman 			.storagebits = 32,
443*2e3ae10cSAlisa-Dariana Roman 			.endianness = IIO_BE,
444*2e3ae10cSAlisa-Dariana Roman 		},
445*2e3ae10cSAlisa-Dariana Roman 	},
446*2e3ae10cSAlisa-Dariana Roman 	{
447*2e3ae10cSAlisa-Dariana Roman 		.type = IIO_VOLTAGE,
448*2e3ae10cSAlisa-Dariana Roman 		.differential = 1,
449*2e3ae10cSAlisa-Dariana Roman 		.indexed = 1,
450*2e3ae10cSAlisa-Dariana Roman 		.channel = 1,
451*2e3ae10cSAlisa-Dariana Roman 		.channel2 = 2,
452*2e3ae10cSAlisa-Dariana Roman 		.address = AD7191_CH_AIN1_AIN2,
453*2e3ae10cSAlisa-Dariana Roman 		.info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
454*2e3ae10cSAlisa-Dariana Roman 				      BIT(IIO_CHAN_INFO_OFFSET) |
455*2e3ae10cSAlisa-Dariana Roman 				      BIT(IIO_CHAN_INFO_SAMP_FREQ),
456*2e3ae10cSAlisa-Dariana Roman 		.info_mask_shared_by_all_available = BIT(IIO_CHAN_INFO_SAMP_FREQ),
457*2e3ae10cSAlisa-Dariana Roman 		.info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE),
458*2e3ae10cSAlisa-Dariana Roman 		.info_mask_shared_by_type_available = BIT(IIO_CHAN_INFO_SCALE),
459*2e3ae10cSAlisa-Dariana Roman 		.scan_index = 1,
460*2e3ae10cSAlisa-Dariana Roman 		.scan_type = {
461*2e3ae10cSAlisa-Dariana Roman 			.sign = 'u',
462*2e3ae10cSAlisa-Dariana Roman 			.realbits = 24,
463*2e3ae10cSAlisa-Dariana Roman 			.storagebits = 32,
464*2e3ae10cSAlisa-Dariana Roman 			.endianness = IIO_BE,
465*2e3ae10cSAlisa-Dariana Roman 		},
466*2e3ae10cSAlisa-Dariana Roman 	},
467*2e3ae10cSAlisa-Dariana Roman 	{
468*2e3ae10cSAlisa-Dariana Roman 		.type = IIO_VOLTAGE,
469*2e3ae10cSAlisa-Dariana Roman 		.differential = 1,
470*2e3ae10cSAlisa-Dariana Roman 		.indexed = 1,
471*2e3ae10cSAlisa-Dariana Roman 		.channel = 3,
472*2e3ae10cSAlisa-Dariana Roman 		.channel2 = 4,
473*2e3ae10cSAlisa-Dariana Roman 		.address = AD7191_CH_AIN3_AIN4,
474*2e3ae10cSAlisa-Dariana Roman 		.info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
475*2e3ae10cSAlisa-Dariana Roman 				      BIT(IIO_CHAN_INFO_OFFSET) |
476*2e3ae10cSAlisa-Dariana Roman 				      BIT(IIO_CHAN_INFO_SAMP_FREQ),
477*2e3ae10cSAlisa-Dariana Roman 		.info_mask_shared_by_all_available = BIT(IIO_CHAN_INFO_SAMP_FREQ),
478*2e3ae10cSAlisa-Dariana Roman 		.info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE),
479*2e3ae10cSAlisa-Dariana Roman 		.info_mask_shared_by_type_available = BIT(IIO_CHAN_INFO_SCALE),
480*2e3ae10cSAlisa-Dariana Roman 		.scan_index = 2,
481*2e3ae10cSAlisa-Dariana Roman 		.scan_type = {
482*2e3ae10cSAlisa-Dariana Roman 			.sign = 'u',
483*2e3ae10cSAlisa-Dariana Roman 			.realbits = 24,
484*2e3ae10cSAlisa-Dariana Roman 			.storagebits = 32,
485*2e3ae10cSAlisa-Dariana Roman 			.endianness = IIO_BE,
486*2e3ae10cSAlisa-Dariana Roman 		},
487*2e3ae10cSAlisa-Dariana Roman 	},
488*2e3ae10cSAlisa-Dariana Roman 	IIO_CHAN_SOFT_TIMESTAMP(3),
489*2e3ae10cSAlisa-Dariana Roman };
490*2e3ae10cSAlisa-Dariana Roman 
491*2e3ae10cSAlisa-Dariana Roman static int ad7191_probe(struct spi_device *spi)
492*2e3ae10cSAlisa-Dariana Roman {
493*2e3ae10cSAlisa-Dariana Roman 	struct device *dev = &spi->dev;
494*2e3ae10cSAlisa-Dariana Roman 	struct ad7191_state *st;
495*2e3ae10cSAlisa-Dariana Roman 	struct iio_dev *indio_dev;
496*2e3ae10cSAlisa-Dariana Roman 	int ret;
497*2e3ae10cSAlisa-Dariana Roman 
498*2e3ae10cSAlisa-Dariana Roman 	indio_dev = devm_iio_device_alloc(dev, sizeof(*st));
499*2e3ae10cSAlisa-Dariana Roman 	if (!indio_dev)
500*2e3ae10cSAlisa-Dariana Roman 		return -ENOMEM;
501*2e3ae10cSAlisa-Dariana Roman 
502*2e3ae10cSAlisa-Dariana Roman 	st = iio_priv(indio_dev);
503*2e3ae10cSAlisa-Dariana Roman 
504*2e3ae10cSAlisa-Dariana Roman 	ret = devm_mutex_init(dev, &st->lock);
505*2e3ae10cSAlisa-Dariana Roman 	if (ret)
506*2e3ae10cSAlisa-Dariana Roman 		return ret;
507*2e3ae10cSAlisa-Dariana Roman 
508*2e3ae10cSAlisa-Dariana Roman 	indio_dev->name = "ad7191";
509*2e3ae10cSAlisa-Dariana Roman 	indio_dev->modes = INDIO_DIRECT_MODE;
510*2e3ae10cSAlisa-Dariana Roman 	indio_dev->channels = ad7191_channels;
511*2e3ae10cSAlisa-Dariana Roman 	indio_dev->num_channels = ARRAY_SIZE(ad7191_channels);
512*2e3ae10cSAlisa-Dariana Roman 	indio_dev->info = &ad7191_info;
513*2e3ae10cSAlisa-Dariana Roman 
514*2e3ae10cSAlisa-Dariana Roman 	ret = ad_sd_init(&st->sd, indio_dev, spi, &ad7191_sigma_delta_info);
515*2e3ae10cSAlisa-Dariana Roman 	if (ret)
516*2e3ae10cSAlisa-Dariana Roman 		return ret;
517*2e3ae10cSAlisa-Dariana Roman 
518*2e3ae10cSAlisa-Dariana Roman 	ret = devm_ad_sd_setup_buffer_and_trigger(dev, indio_dev);
519*2e3ae10cSAlisa-Dariana Roman 	if (ret)
520*2e3ae10cSAlisa-Dariana Roman 		return ret;
521*2e3ae10cSAlisa-Dariana Roman 
522*2e3ae10cSAlisa-Dariana Roman 	ret = ad7191_setup(indio_dev);
523*2e3ae10cSAlisa-Dariana Roman 	if (ret)
524*2e3ae10cSAlisa-Dariana Roman 		return ret;
525*2e3ae10cSAlisa-Dariana Roman 
526*2e3ae10cSAlisa-Dariana Roman 	return devm_iio_device_register(dev, indio_dev);
527*2e3ae10cSAlisa-Dariana Roman }
528*2e3ae10cSAlisa-Dariana Roman 
529*2e3ae10cSAlisa-Dariana Roman static const struct of_device_id ad7191_of_match[] = {
530*2e3ae10cSAlisa-Dariana Roman 	{ .compatible = "adi,ad7191", },
531*2e3ae10cSAlisa-Dariana Roman 	{ }
532*2e3ae10cSAlisa-Dariana Roman };
533*2e3ae10cSAlisa-Dariana Roman MODULE_DEVICE_TABLE(of, ad7191_of_match);
534*2e3ae10cSAlisa-Dariana Roman 
535*2e3ae10cSAlisa-Dariana Roman static const struct spi_device_id ad7191_id_table[] = {
536*2e3ae10cSAlisa-Dariana Roman 	{ "ad7191" },
537*2e3ae10cSAlisa-Dariana Roman 	{ }
538*2e3ae10cSAlisa-Dariana Roman };
539*2e3ae10cSAlisa-Dariana Roman MODULE_DEVICE_TABLE(spi, ad7191_id_table);
540*2e3ae10cSAlisa-Dariana Roman 
541*2e3ae10cSAlisa-Dariana Roman static struct spi_driver ad7191_driver = {
542*2e3ae10cSAlisa-Dariana Roman 	.driver = {
543*2e3ae10cSAlisa-Dariana Roman 		.name = "ad7191",
544*2e3ae10cSAlisa-Dariana Roman 		.of_match_table = ad7191_of_match,
545*2e3ae10cSAlisa-Dariana Roman 	},
546*2e3ae10cSAlisa-Dariana Roman 	.probe = ad7191_probe,
547*2e3ae10cSAlisa-Dariana Roman 	.id_table = ad7191_id_table,
548*2e3ae10cSAlisa-Dariana Roman };
549*2e3ae10cSAlisa-Dariana Roman module_spi_driver(ad7191_driver);
550*2e3ae10cSAlisa-Dariana Roman 
551*2e3ae10cSAlisa-Dariana Roman MODULE_AUTHOR("Alisa-Dariana Roman <alisa.roman@analog.com>");
552*2e3ae10cSAlisa-Dariana Roman MODULE_DESCRIPTION("Analog Devices AD7191 ADC");
553*2e3ae10cSAlisa-Dariana Roman MODULE_LICENSE("GPL");
554*2e3ae10cSAlisa-Dariana Roman MODULE_IMPORT_NS("IIO_AD_SIGMA_DELTA");
555