xref: /linux/drivers/iio/adc/ad7949.c (revision 300a0cfe9f375b2843bcb331bcfa7503475ef5dd)
1 // SPDX-License-Identifier: GPL-2.0
2 /* ad7949.c - Analog Devices ADC driver 14/16 bits 4/8 channels
3  *
4  * Copyright (C) 2018 CMC NV
5  *
6  * https://www.analog.com/media/en/technical-documentation/data-sheets/AD7949.pdf
7  */
8 
9 #include <linux/delay.h>
10 #include <linux/iio/iio.h>
11 #include <linux/module.h>
12 #include <linux/regulator/consumer.h>
13 #include <linux/spi/spi.h>
14 #include <linux/bitfield.h>
15 
16 #define AD7949_CFG_MASK_TOTAL		GENMASK(13, 0)
17 
18 /* CFG: Configuration Update */
19 #define AD7949_CFG_MASK_OVERWRITE	BIT(13)
20 
21 /* INCC: Input Channel Configuration */
22 #define AD7949_CFG_MASK_INCC		GENMASK(12, 10)
23 #define AD7949_CFG_VAL_INCC_UNIPOLAR_GND	7
24 #define AD7949_CFG_VAL_INCC_UNIPOLAR_COMM	6
25 #define AD7949_CFG_VAL_INCC_UNIPOLAR_DIFF	4
26 #define AD7949_CFG_VAL_INCC_TEMP		3
27 #define AD7949_CFG_VAL_INCC_BIPOLAR		2
28 #define AD7949_CFG_VAL_INCC_BIPOLAR_DIFF	0
29 
30 /* INX: Input channel Selection in a binary fashion */
31 #define AD7949_CFG_MASK_INX		GENMASK(9, 7)
32 
33 /* BW: select bandwidth for low-pass filter. Full or Quarter */
34 #define AD7949_CFG_MASK_BW_FULL		BIT(6)
35 
36 /* REF: reference/buffer selection */
37 #define AD7949_CFG_MASK_REF		GENMASK(5, 3)
38 #define AD7949_CFG_VAL_REF_EXT_TEMP_BUF		3
39 #define AD7949_CFG_VAL_REF_EXT_TEMP		2
40 #define AD7949_CFG_VAL_REF_INT_4096		1
41 #define AD7949_CFG_VAL_REF_INT_2500		0
42 #define AD7949_CFG_VAL_REF_EXTERNAL		BIT(1)
43 
44 /* SEQ: channel sequencer. Allows for scanning channels */
45 #define AD7949_CFG_MASK_SEQ		GENMASK(2, 1)
46 
47 /* RB: Read back the CFG register */
48 #define AD7949_CFG_MASK_RBN		BIT(0)
49 
50 enum {
51 	ID_AD7949 = 0,
52 	ID_AD7682,
53 	ID_AD7689,
54 };
55 
56 struct ad7949_adc_spec {
57 	u8 num_channels;
58 	u8 resolution;
59 };
60 
61 static const struct ad7949_adc_spec ad7949_adc_spec[] = {
62 	[ID_AD7949] = { .num_channels = 8, .resolution = 14 },
63 	[ID_AD7682] = { .num_channels = 4, .resolution = 16 },
64 	[ID_AD7689] = { .num_channels = 8, .resolution = 16 },
65 };
66 
67 /**
68  * struct ad7949_adc_chip - AD ADC chip
69  * @lock: protects write sequences
70  * @vref: regulator generating Vref
71  * @indio_dev: reference to iio structure
72  * @spi: reference to spi structure
73  * @refsel: reference selection
74  * @resolution: resolution of the chip
75  * @cfg: copy of the configuration register
76  * @current_channel: current channel in use
77  * @buffer: buffer to send / receive data to / from device
78  * @buf8b: be16 buffer to exchange data with the device in 8-bit transfers
79  */
80 struct ad7949_adc_chip {
81 	struct mutex lock;
82 	struct regulator *vref;
83 	struct iio_dev *indio_dev;
84 	struct spi_device *spi;
85 	u32 refsel;
86 	u8 resolution;
87 	u16 cfg;
88 	unsigned int current_channel;
89 	u16 buffer __aligned(IIO_DMA_MINALIGN);
90 	__be16 buf8b;
91 };
92 
93 static int ad7949_spi_write_cfg(struct ad7949_adc_chip *ad7949_adc, u16 val,
94 				u16 mask)
95 {
96 	int ret;
97 
98 	ad7949_adc->cfg = (val & mask) | (ad7949_adc->cfg & ~mask);
99 
100 	switch (ad7949_adc->spi->bits_per_word) {
101 	case 16:
102 		ad7949_adc->buffer = ad7949_adc->cfg << 2;
103 		ret = spi_write(ad7949_adc->spi, &ad7949_adc->buffer, 2);
104 		break;
105 	case 14:
106 		ad7949_adc->buffer = ad7949_adc->cfg;
107 		ret = spi_write(ad7949_adc->spi, &ad7949_adc->buffer, 2);
108 		break;
109 	case 8:
110 		/* Here, type is big endian as it must be sent in two transfers */
111 		ad7949_adc->buf8b = cpu_to_be16(ad7949_adc->cfg << 2);
112 		ret = spi_write(ad7949_adc->spi, &ad7949_adc->buf8b, 2);
113 		break;
114 	default:
115 		dev_err(&ad7949_adc->indio_dev->dev, "unsupported BPW\n");
116 		return -EINVAL;
117 	}
118 
119 	/*
120 	 * This delay is to avoid a new request before the required time to
121 	 * send a new command to the device
122 	 */
123 	udelay(2);
124 	return ret;
125 }
126 
127 static int ad7949_spi_read_channel(struct ad7949_adc_chip *ad7949_adc, int *val,
128 				   unsigned int channel)
129 {
130 	int ret;
131 	int i;
132 
133 	/*
134 	 * 1: write CFG for sample N and read old data (sample N-2)
135 	 * 2: if CFG was not changed since sample N-1 then we'll get good data
136 	 *    at the next xfer, so we bail out now, otherwise we write something
137 	 *    and we read garbage (sample N-1 configuration).
138 	 */
139 	for (i = 0; i < 2; i++) {
140 		ret = ad7949_spi_write_cfg(ad7949_adc,
141 					   FIELD_PREP(AD7949_CFG_MASK_INX, channel),
142 					   AD7949_CFG_MASK_INX);
143 		if (ret)
144 			return ret;
145 		if (channel == ad7949_adc->current_channel)
146 			break;
147 	}
148 
149 	/* 3: write something and read actual data */
150 	if (ad7949_adc->spi->bits_per_word == 8)
151 		ret = spi_read(ad7949_adc->spi, &ad7949_adc->buf8b, 2);
152 	else
153 		ret = spi_read(ad7949_adc->spi, &ad7949_adc->buffer, 2);
154 
155 	if (ret)
156 		return ret;
157 
158 	/*
159 	 * This delay is to avoid a new request before the required time to
160 	 * send a new command to the device
161 	 */
162 	udelay(2);
163 
164 	ad7949_adc->current_channel = channel;
165 
166 	switch (ad7949_adc->spi->bits_per_word) {
167 	case 16:
168 		*val = ad7949_adc->buffer;
169 		/* Shift-out padding bits */
170 		*val >>= 16 - ad7949_adc->resolution;
171 		break;
172 	case 14:
173 		*val = ad7949_adc->buffer & GENMASK(13, 0);
174 		break;
175 	case 8:
176 		/* Here, type is big endian as data was sent in two transfers */
177 		*val = be16_to_cpu(ad7949_adc->buf8b);
178 		/* Shift-out padding bits */
179 		*val >>= 16 - ad7949_adc->resolution;
180 		break;
181 	default:
182 		dev_err(&ad7949_adc->indio_dev->dev, "unsupported BPW\n");
183 		return -EINVAL;
184 	}
185 
186 	return 0;
187 }
188 
189 #define AD7949_ADC_CHANNEL(chan) {				\
190 	.type = IIO_VOLTAGE,					\
191 	.indexed = 1,						\
192 	.channel = (chan),					\
193 	.info_mask_separate = BIT(IIO_CHAN_INFO_RAW),		\
194 	.info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE),	\
195 }
196 
197 static const struct iio_chan_spec ad7949_adc_channels[] = {
198 	AD7949_ADC_CHANNEL(0),
199 	AD7949_ADC_CHANNEL(1),
200 	AD7949_ADC_CHANNEL(2),
201 	AD7949_ADC_CHANNEL(3),
202 	AD7949_ADC_CHANNEL(4),
203 	AD7949_ADC_CHANNEL(5),
204 	AD7949_ADC_CHANNEL(6),
205 	AD7949_ADC_CHANNEL(7),
206 };
207 
208 static int ad7949_spi_read_raw(struct iio_dev *indio_dev,
209 			   struct iio_chan_spec const *chan,
210 			   int *val, int *val2, long mask)
211 {
212 	struct ad7949_adc_chip *ad7949_adc = iio_priv(indio_dev);
213 	int ret;
214 
215 	if (!val)
216 		return -EINVAL;
217 
218 	switch (mask) {
219 	case IIO_CHAN_INFO_RAW:
220 		mutex_lock(&ad7949_adc->lock);
221 		ret = ad7949_spi_read_channel(ad7949_adc, val, chan->channel);
222 		mutex_unlock(&ad7949_adc->lock);
223 
224 		if (ret < 0)
225 			return ret;
226 
227 		return IIO_VAL_INT;
228 
229 	case IIO_CHAN_INFO_SCALE:
230 		switch (ad7949_adc->refsel) {
231 		case AD7949_CFG_VAL_REF_INT_2500:
232 			*val = 2500;
233 			break;
234 		case AD7949_CFG_VAL_REF_INT_4096:
235 			*val = 4096;
236 			break;
237 		case AD7949_CFG_VAL_REF_EXT_TEMP:
238 		case AD7949_CFG_VAL_REF_EXT_TEMP_BUF:
239 			ret = regulator_get_voltage(ad7949_adc->vref);
240 			if (ret < 0)
241 				return ret;
242 
243 			/* convert value back to mV */
244 			*val = ret / 1000;
245 			break;
246 		}
247 
248 		*val2 = (1 << ad7949_adc->resolution) - 1;
249 		return IIO_VAL_FRACTIONAL;
250 	}
251 
252 	return -EINVAL;
253 }
254 
255 static int ad7949_spi_reg_access(struct iio_dev *indio_dev,
256 			unsigned int reg, unsigned int writeval,
257 			unsigned int *readval)
258 {
259 	struct ad7949_adc_chip *ad7949_adc = iio_priv(indio_dev);
260 	int ret = 0;
261 
262 	if (readval)
263 		*readval = ad7949_adc->cfg;
264 	else
265 		ret = ad7949_spi_write_cfg(ad7949_adc, writeval,
266 					   AD7949_CFG_MASK_TOTAL);
267 
268 	return ret;
269 }
270 
271 static const struct iio_info ad7949_spi_info = {
272 	.read_raw = ad7949_spi_read_raw,
273 	.debugfs_reg_access = ad7949_spi_reg_access,
274 };
275 
276 static int ad7949_spi_init(struct ad7949_adc_chip *ad7949_adc)
277 {
278 	int ret;
279 	int val;
280 	u16 cfg;
281 
282 	ad7949_adc->current_channel = 0;
283 
284 	cfg = FIELD_PREP(AD7949_CFG_MASK_OVERWRITE, 1) |
285 		FIELD_PREP(AD7949_CFG_MASK_INCC, AD7949_CFG_VAL_INCC_UNIPOLAR_GND) |
286 		FIELD_PREP(AD7949_CFG_MASK_INX, ad7949_adc->current_channel) |
287 		FIELD_PREP(AD7949_CFG_MASK_BW_FULL, 1) |
288 		FIELD_PREP(AD7949_CFG_MASK_REF, ad7949_adc->refsel) |
289 		FIELD_PREP(AD7949_CFG_MASK_SEQ, 0x0) |
290 		FIELD_PREP(AD7949_CFG_MASK_RBN, 1);
291 
292 	ret = ad7949_spi_write_cfg(ad7949_adc, cfg, AD7949_CFG_MASK_TOTAL);
293 
294 	/*
295 	 * Do two dummy conversions to apply the first configuration setting.
296 	 * Required only after the start up of the device.
297 	 */
298 	ad7949_spi_read_channel(ad7949_adc, &val, ad7949_adc->current_channel);
299 	ad7949_spi_read_channel(ad7949_adc, &val, ad7949_adc->current_channel);
300 
301 	return ret;
302 }
303 
304 static void ad7949_disable_reg(void *reg)
305 {
306 	regulator_disable(reg);
307 }
308 
309 static int ad7949_spi_probe(struct spi_device *spi)
310 {
311 	struct device *dev = &spi->dev;
312 	const struct ad7949_adc_spec *spec;
313 	struct ad7949_adc_chip *ad7949_adc;
314 	struct iio_dev *indio_dev;
315 	u32 tmp;
316 	int ret;
317 
318 	indio_dev = devm_iio_device_alloc(dev, sizeof(*ad7949_adc));
319 	if (!indio_dev) {
320 		dev_err(dev, "can not allocate iio device\n");
321 		return -ENOMEM;
322 	}
323 
324 	indio_dev->info = &ad7949_spi_info;
325 	indio_dev->name = spi_get_device_id(spi)->name;
326 	indio_dev->modes = INDIO_DIRECT_MODE;
327 	indio_dev->channels = ad7949_adc_channels;
328 	spi_set_drvdata(spi, indio_dev);
329 
330 	ad7949_adc = iio_priv(indio_dev);
331 	ad7949_adc->indio_dev = indio_dev;
332 	ad7949_adc->spi = spi;
333 
334 	spec = &ad7949_adc_spec[spi_get_device_id(spi)->driver_data];
335 	indio_dev->num_channels = spec->num_channels;
336 	ad7949_adc->resolution = spec->resolution;
337 
338 	/* Set SPI bits per word */
339 	if (spi_is_bpw_supported(spi, ad7949_adc->resolution)) {
340 		spi->bits_per_word = ad7949_adc->resolution;
341 	} else if (spi_is_bpw_supported(spi, 16)) {
342 		spi->bits_per_word = 16;
343 	} else if (spi_is_bpw_supported(spi, 8)) {
344 		spi->bits_per_word = 8;
345 	} else {
346 		dev_err(dev, "unable to find common BPW with spi controller\n");
347 		return -EINVAL;
348 	}
349 
350 	/* Setup internal voltage reference */
351 	tmp = 4096000;
352 	device_property_read_u32(dev, "adi,internal-ref-microvolt", &tmp);
353 
354 	switch (tmp) {
355 	case 2500000:
356 		ad7949_adc->refsel = AD7949_CFG_VAL_REF_INT_2500;
357 		break;
358 	case 4096000:
359 		ad7949_adc->refsel = AD7949_CFG_VAL_REF_INT_4096;
360 		break;
361 	default:
362 		dev_err(dev, "unsupported internal voltage reference\n");
363 		return -EINVAL;
364 	}
365 
366 	/* Setup external voltage reference, buffered? */
367 	ad7949_adc->vref = devm_regulator_get_optional(dev, "vrefin");
368 	if (IS_ERR(ad7949_adc->vref)) {
369 		ret = PTR_ERR(ad7949_adc->vref);
370 		if (ret != -ENODEV)
371 			return ret;
372 		/* unbuffered? */
373 		ad7949_adc->vref = devm_regulator_get_optional(dev, "vref");
374 		if (IS_ERR(ad7949_adc->vref)) {
375 			ret = PTR_ERR(ad7949_adc->vref);
376 			if (ret != -ENODEV)
377 				return ret;
378 		} else {
379 			ad7949_adc->refsel = AD7949_CFG_VAL_REF_EXT_TEMP;
380 		}
381 	} else {
382 		ad7949_adc->refsel = AD7949_CFG_VAL_REF_EXT_TEMP_BUF;
383 	}
384 
385 	if (ad7949_adc->refsel & AD7949_CFG_VAL_REF_EXTERNAL) {
386 		ret = regulator_enable(ad7949_adc->vref);
387 		if (ret < 0) {
388 			dev_err(dev, "fail to enable regulator\n");
389 			return ret;
390 		}
391 
392 		ret = devm_add_action_or_reset(dev, ad7949_disable_reg,
393 					       ad7949_adc->vref);
394 		if (ret)
395 			return ret;
396 	}
397 
398 	mutex_init(&ad7949_adc->lock);
399 
400 	ret = ad7949_spi_init(ad7949_adc);
401 	if (ret) {
402 		dev_err(dev, "fail to init this device: %d\n", ret);
403 		return ret;
404 	}
405 
406 	ret = devm_iio_device_register(dev, indio_dev);
407 	if (ret)
408 		dev_err(dev, "fail to register iio device: %d\n", ret);
409 
410 	return ret;
411 }
412 
413 static const struct of_device_id ad7949_spi_of_id[] = {
414 	{ .compatible = "adi,ad7949" },
415 	{ .compatible = "adi,ad7682" },
416 	{ .compatible = "adi,ad7689" },
417 	{ }
418 };
419 MODULE_DEVICE_TABLE(of, ad7949_spi_of_id);
420 
421 static const struct spi_device_id ad7949_spi_id[] = {
422 	{ "ad7949", ID_AD7949  },
423 	{ "ad7682", ID_AD7682 },
424 	{ "ad7689", ID_AD7689 },
425 	{ }
426 };
427 MODULE_DEVICE_TABLE(spi, ad7949_spi_id);
428 
429 static struct spi_driver ad7949_spi_driver = {
430 	.driver = {
431 		.name		= "ad7949",
432 		.of_match_table	= ad7949_spi_of_id,
433 	},
434 	.probe	  = ad7949_spi_probe,
435 	.id_table = ad7949_spi_id,
436 };
437 module_spi_driver(ad7949_spi_driver);
438 
439 MODULE_AUTHOR("Charles-Antoine Couret <charles-antoine.couret@essensium.com>");
440 MODULE_DESCRIPTION("Analog Devices 14/16-bit 8-channel ADC driver");
441 MODULE_LICENSE("GPL v2");
442