Merge tag 'trace-printf-v6.13' of git://git.kernel.org/pub/scm/linux/kernel/git/trace...
[drm/drm-misc.git] / drivers / iio / dac / ad7293.c
blob1d403267048240be1bf3d8b2a59685409b9087fd
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3 * AD7293 driver
5 * Copyright 2021 Analog Devices Inc.
6 */
8 #include <linux/bitfield.h>
9 #include <linux/bits.h>
10 #include <linux/delay.h>
11 #include <linux/device.h>
12 #include <linux/gpio/consumer.h>
13 #include <linux/iio/iio.h>
14 #include <linux/mod_devicetable.h>
15 #include <linux/module.h>
16 #include <linux/regulator/consumer.h>
17 #include <linux/spi/spi.h>
19 #include <linux/unaligned.h>
21 #define AD7293_R1B BIT(16)
22 #define AD7293_R2B BIT(17)
23 #define AD7293_PAGE_ADDR_MSK GENMASK(15, 8)
24 #define AD7293_PAGE(x) FIELD_PREP(AD7293_PAGE_ADDR_MSK, x)
26 /* AD7293 Register Map Common */
27 #define AD7293_REG_NO_OP (AD7293_R1B | AD7293_PAGE(0x0) | 0x0)
28 #define AD7293_REG_PAGE_SELECT (AD7293_R1B | AD7293_PAGE(0x0) | 0x1)
29 #define AD7293_REG_CONV_CMD (AD7293_R2B | AD7293_PAGE(0x0) | 0x2)
30 #define AD7293_REG_RESULT (AD7293_R1B | AD7293_PAGE(0x0) | 0x3)
31 #define AD7293_REG_DAC_EN (AD7293_R1B | AD7293_PAGE(0x0) | 0x4)
32 #define AD7293_REG_DEVICE_ID (AD7293_R2B | AD7293_PAGE(0x0) | 0xC)
33 #define AD7293_REG_SOFT_RESET (AD7293_R2B | AD7293_PAGE(0x0) | 0xF)
35 /* AD7293 Register Map Page 0x0 */
36 #define AD7293_REG_VIN0 (AD7293_R2B | AD7293_PAGE(0x0) | 0x10)
37 #define AD7293_REG_VIN1 (AD7293_R2B | AD7293_PAGE(0x0) | 0x11)
38 #define AD7293_REG_VIN2 (AD7293_R2B | AD7293_PAGE(0x0) | 0x12)
39 #define AD7293_REG_VIN3 (AD7293_R2B | AD7293_PAGE(0x0) | 0x13)
40 #define AD7293_REG_TSENSE_INT (AD7293_R2B | AD7293_PAGE(0x0) | 0x20)
41 #define AD7293_REG_TSENSE_D0 (AD7293_R2B | AD7293_PAGE(0x0) | 0x21)
42 #define AD7293_REG_TSENSE_D1 (AD7293_R2B | AD7293_PAGE(0x0) | 0x22)
43 #define AD7293_REG_ISENSE_0 (AD7293_R2B | AD7293_PAGE(0x0) | 0x28)
44 #define AD7293_REG_ISENSE_1 (AD7293_R2B | AD7293_PAGE(0x0) | 0x29)
45 #define AD7293_REG_ISENSE_2 (AD7293_R2B | AD7293_PAGE(0x0) | 0x2A)
46 #define AD7293_REG_ISENSE_3 (AD7293_R2B | AD7293_PAGE(0x0) | 0x2B)
47 #define AD7293_REG_UNI_VOUT0 (AD7293_R2B | AD7293_PAGE(0x0) | 0x30)
48 #define AD7293_REG_UNI_VOUT1 (AD7293_R2B | AD7293_PAGE(0x0) | 0x31)
49 #define AD7293_REG_UNI_VOUT2 (AD7293_R2B | AD7293_PAGE(0x0) | 0x32)
50 #define AD7293_REG_UNI_VOUT3 (AD7293_R2B | AD7293_PAGE(0x0) | 0x33)
51 #define AD7293_REG_BI_VOUT0 (AD7293_R2B | AD7293_PAGE(0x0) | 0x34)
52 #define AD7293_REG_BI_VOUT1 (AD7293_R2B | AD7293_PAGE(0x0) | 0x35)
53 #define AD7293_REG_BI_VOUT2 (AD7293_R2B | AD7293_PAGE(0x0) | 0x36)
54 #define AD7293_REG_BI_VOUT3 (AD7293_R2B | AD7293_PAGE(0x0) | 0x37)
56 /* AD7293 Register Map Page 0x2 */
57 #define AD7293_REG_DIGITAL_OUT_EN (AD7293_R2B | AD7293_PAGE(0x2) | 0x11)
58 #define AD7293_REG_DIGITAL_INOUT_FUNC (AD7293_R2B | AD7293_PAGE(0x2) | 0x12)
59 #define AD7293_REG_DIGITAL_FUNC_POL (AD7293_R2B | AD7293_PAGE(0x2) | 0x13)
60 #define AD7293_REG_GENERAL (AD7293_R2B | AD7293_PAGE(0x2) | 0x14)
61 #define AD7293_REG_VINX_RANGE0 (AD7293_R2B | AD7293_PAGE(0x2) | 0x15)
62 #define AD7293_REG_VINX_RANGE1 (AD7293_R2B | AD7293_PAGE(0x2) | 0x16)
63 #define AD7293_REG_VINX_DIFF_SE (AD7293_R2B | AD7293_PAGE(0x2) | 0x17)
64 #define AD7293_REG_VINX_FILTER (AD7293_R2B | AD7293_PAGE(0x2) | 0x18)
65 #define AD7293_REG_BG_EN (AD7293_R2B | AD7293_PAGE(0x2) | 0x19)
66 #define AD7293_REG_CONV_DELAY (AD7293_R2B | AD7293_PAGE(0x2) | 0x1A)
67 #define AD7293_REG_TSENSE_BG_EN (AD7293_R2B | AD7293_PAGE(0x2) | 0x1B)
68 #define AD7293_REG_ISENSE_BG_EN (AD7293_R2B | AD7293_PAGE(0x2) | 0x1C)
69 #define AD7293_REG_ISENSE_GAIN (AD7293_R2B | AD7293_PAGE(0x2) | 0x1D)
70 #define AD7293_REG_DAC_SNOOZE_O (AD7293_R2B | AD7293_PAGE(0x2) | 0x1F)
71 #define AD7293_REG_DAC_SNOOZE_1 (AD7293_R2B | AD7293_PAGE(0x2) | 0x20)
72 #define AD7293_REG_RSX_MON_BG_EN (AD7293_R2B | AD7293_PAGE(0x2) | 0x23)
73 #define AD7293_REG_INTEGR_CL (AD7293_R2B | AD7293_PAGE(0x2) | 0x28)
74 #define AD7293_REG_PA_ON_CTRL (AD7293_R2B | AD7293_PAGE(0x2) | 0x29)
75 #define AD7293_REG_RAMP_TIME_0 (AD7293_R2B | AD7293_PAGE(0x2) | 0x2A)
76 #define AD7293_REG_RAMP_TIME_1 (AD7293_R2B | AD7293_PAGE(0x2) | 0x2B)
77 #define AD7293_REG_RAMP_TIME_2 (AD7293_R2B | AD7293_PAGE(0x2) | 0x2C)
78 #define AD7293_REG_RAMP_TIME_3 (AD7293_R2B | AD7293_PAGE(0x2) | 0x2D)
79 #define AD7293_REG_CL_FR_IT (AD7293_R2B | AD7293_PAGE(0x2) | 0x2E)
80 #define AD7293_REG_INTX_AVSS_AVDD (AD7293_R2B | AD7293_PAGE(0x2) | 0x2F)
82 /* AD7293 Register Map Page 0x3 */
83 #define AD7293_REG_VINX_SEQ (AD7293_R2B | AD7293_PAGE(0x3) | 0x10)
84 #define AD7293_REG_ISENSEX_TSENSEX_SEQ (AD7293_R2B | AD7293_PAGE(0x3) | 0x11)
85 #define AD7293_REG_RSX_MON_BI_VOUTX_SEQ (AD7293_R2B | AD7293_PAGE(0x3) | 0x12)
87 /* AD7293 Register Map Page 0xE */
88 #define AD7293_REG_VIN0_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x10)
89 #define AD7293_REG_VIN1_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x11)
90 #define AD7293_REG_VIN2_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x12)
91 #define AD7293_REG_VIN3_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x13)
92 #define AD7293_REG_TSENSE_INT_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x20)
93 #define AD7293_REG_TSENSE_D0_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x21)
94 #define AD7293_REG_TSENSE_D1_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x22)
95 #define AD7293_REG_ISENSE0_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x28)
96 #define AD7293_REG_ISENSE1_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x29)
97 #define AD7293_REG_ISENSE2_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x2A)
98 #define AD7293_REG_ISENSE3_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x2B)
99 #define AD7293_REG_UNI_VOUT0_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x30)
100 #define AD7293_REG_UNI_VOUT1_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x31)
101 #define AD7293_REG_UNI_VOUT2_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x32)
102 #define AD7293_REG_UNI_VOUT3_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x33)
103 #define AD7293_REG_BI_VOUT0_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x34)
104 #define AD7293_REG_BI_VOUT1_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x35)
105 #define AD7293_REG_BI_VOUT2_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x36)
106 #define AD7293_REG_BI_VOUT3_OFFSET (AD7293_R1B | AD7293_PAGE(0xE) | 0x37)
108 /* AD7293 Miscellaneous Definitions */
109 #define AD7293_READ BIT(7)
110 #define AD7293_TRANSF_LEN_MSK GENMASK(17, 16)
112 #define AD7293_REG_ADDR_MSK GENMASK(7, 0)
113 #define AD7293_REG_VOUT_OFFSET_MSK GENMASK(5, 4)
114 #define AD7293_REG_DATA_RAW_MSK GENMASK(15, 4)
115 #define AD7293_REG_VINX_RANGE_GET_CH_MSK(x, ch) (((x) >> (ch)) & 0x1)
116 #define AD7293_REG_VINX_RANGE_SET_CH_MSK(x, ch) (((x) & 0x1) << (ch))
117 #define AD7293_CHIP_ID 0x18
119 enum ad7293_ch_type {
120 AD7293_ADC_VINX,
121 AD7293_ADC_TSENSE,
122 AD7293_ADC_ISENSE,
123 AD7293_DAC,
126 enum ad7293_max_offset {
127 AD7293_TSENSE_MIN_OFFSET_CH = 4,
128 AD7293_ISENSE_MIN_OFFSET_CH = 7,
129 AD7293_VOUT_MIN_OFFSET_CH = 11,
130 AD7293_VOUT_MAX_OFFSET_CH = 18,
133 static const int dac_offset_table[] = {0, 1, 2};
135 static const int isense_gain_table[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
137 static const int adc_range_table[] = {0, 1, 2, 3};
139 struct ad7293_state {
140 struct spi_device *spi;
141 /* Protect against concurrent accesses to the device, page selection and data content */
142 struct mutex lock;
143 struct gpio_desc *gpio_reset;
144 struct regulator *reg_avdd;
145 struct regulator *reg_vdrive;
146 u8 page_select;
147 u8 data[3] __aligned(IIO_DMA_MINALIGN);
150 static int ad7293_page_select(struct ad7293_state *st, unsigned int reg)
152 int ret;
154 if (st->page_select != FIELD_GET(AD7293_PAGE_ADDR_MSK, reg)) {
155 st->data[0] = FIELD_GET(AD7293_REG_ADDR_MSK, AD7293_REG_PAGE_SELECT);
156 st->data[1] = FIELD_GET(AD7293_PAGE_ADDR_MSK, reg);
158 ret = spi_write(st->spi, &st->data[0], 2);
159 if (ret)
160 return ret;
162 st->page_select = FIELD_GET(AD7293_PAGE_ADDR_MSK, reg);
165 return 0;
168 static int __ad7293_spi_read(struct ad7293_state *st, unsigned int reg,
169 u16 *val)
171 int ret;
172 unsigned int length;
173 struct spi_transfer t = {0};
175 length = FIELD_GET(AD7293_TRANSF_LEN_MSK, reg);
177 ret = ad7293_page_select(st, reg);
178 if (ret)
179 return ret;
181 st->data[0] = AD7293_READ | FIELD_GET(AD7293_REG_ADDR_MSK, reg);
182 st->data[1] = 0x0;
183 st->data[2] = 0x0;
185 t.tx_buf = &st->data[0];
186 t.rx_buf = &st->data[0];
187 t.len = length + 1;
189 ret = spi_sync_transfer(st->spi, &t, 1);
190 if (ret)
191 return ret;
193 if (length == 1)
194 *val = st->data[1];
195 else
196 *val = get_unaligned_be16(&st->data[1]);
198 return 0;
201 static int ad7293_spi_read(struct ad7293_state *st, unsigned int reg,
202 u16 *val)
204 int ret;
206 mutex_lock(&st->lock);
207 ret = __ad7293_spi_read(st, reg, val);
208 mutex_unlock(&st->lock);
210 return ret;
213 static int __ad7293_spi_write(struct ad7293_state *st, unsigned int reg,
214 u16 val)
216 int ret;
217 unsigned int length;
219 length = FIELD_GET(AD7293_TRANSF_LEN_MSK, reg);
221 ret = ad7293_page_select(st, reg);
222 if (ret)
223 return ret;
225 st->data[0] = FIELD_GET(AD7293_REG_ADDR_MSK, reg);
227 if (length == 1)
228 st->data[1] = val;
229 else
230 put_unaligned_be16(val, &st->data[1]);
232 return spi_write(st->spi, &st->data[0], length + 1);
235 static int ad7293_spi_write(struct ad7293_state *st, unsigned int reg,
236 u16 val)
238 int ret;
240 mutex_lock(&st->lock);
241 ret = __ad7293_spi_write(st, reg, val);
242 mutex_unlock(&st->lock);
244 return ret;
247 static int __ad7293_spi_update_bits(struct ad7293_state *st, unsigned int reg,
248 u16 mask, u16 val)
250 int ret;
251 u16 data, temp;
253 ret = __ad7293_spi_read(st, reg, &data);
254 if (ret)
255 return ret;
257 temp = (data & ~mask) | (val & mask);
259 return __ad7293_spi_write(st, reg, temp);
262 static int ad7293_spi_update_bits(struct ad7293_state *st, unsigned int reg,
263 u16 mask, u16 val)
265 int ret;
267 mutex_lock(&st->lock);
268 ret = __ad7293_spi_update_bits(st, reg, mask, val);
269 mutex_unlock(&st->lock);
271 return ret;
274 static int ad7293_adc_get_scale(struct ad7293_state *st, unsigned int ch,
275 u16 *range)
277 int ret;
278 u16 data;
280 mutex_lock(&st->lock);
282 ret = __ad7293_spi_read(st, AD7293_REG_VINX_RANGE1, &data);
283 if (ret)
284 goto exit;
286 *range = AD7293_REG_VINX_RANGE_GET_CH_MSK(data, ch);
288 ret = __ad7293_spi_read(st, AD7293_REG_VINX_RANGE0, &data);
289 if (ret)
290 goto exit;
292 *range |= AD7293_REG_VINX_RANGE_GET_CH_MSK(data, ch) << 1;
294 exit:
295 mutex_unlock(&st->lock);
297 return ret;
300 static int ad7293_adc_set_scale(struct ad7293_state *st, unsigned int ch,
301 u16 range)
303 int ret;
304 unsigned int ch_msk = BIT(ch);
306 mutex_lock(&st->lock);
307 ret = __ad7293_spi_update_bits(st, AD7293_REG_VINX_RANGE1, ch_msk,
308 AD7293_REG_VINX_RANGE_SET_CH_MSK(range, ch));
309 if (ret)
310 goto exit;
312 ret = __ad7293_spi_update_bits(st, AD7293_REG_VINX_RANGE0, ch_msk,
313 AD7293_REG_VINX_RANGE_SET_CH_MSK((range >> 1), ch));
315 exit:
316 mutex_unlock(&st->lock);
318 return ret;
321 static int ad7293_get_offset(struct ad7293_state *st, unsigned int ch,
322 u16 *offset)
324 if (ch < AD7293_TSENSE_MIN_OFFSET_CH)
325 return ad7293_spi_read(st, AD7293_REG_VIN0_OFFSET + ch, offset);
326 else if (ch < AD7293_ISENSE_MIN_OFFSET_CH)
327 return ad7293_spi_read(st, AD7293_REG_TSENSE_INT_OFFSET + (ch - 4), offset);
328 else if (ch < AD7293_VOUT_MIN_OFFSET_CH)
329 return ad7293_spi_read(st, AD7293_REG_ISENSE0_OFFSET + (ch - 7), offset);
330 else if (ch <= AD7293_VOUT_MAX_OFFSET_CH)
331 return ad7293_spi_read(st, AD7293_REG_UNI_VOUT0_OFFSET + (ch - 11), offset);
333 return -EINVAL;
336 static int ad7293_set_offset(struct ad7293_state *st, unsigned int ch,
337 u16 offset)
339 if (ch < AD7293_TSENSE_MIN_OFFSET_CH)
340 return ad7293_spi_write(st, AD7293_REG_VIN0_OFFSET + ch,
341 offset);
342 else if (ch < AD7293_ISENSE_MIN_OFFSET_CH)
343 return ad7293_spi_write(st,
344 AD7293_REG_TSENSE_INT_OFFSET +
345 (ch - AD7293_TSENSE_MIN_OFFSET_CH),
346 offset);
347 else if (ch < AD7293_VOUT_MIN_OFFSET_CH)
348 return ad7293_spi_write(st,
349 AD7293_REG_ISENSE0_OFFSET +
350 (ch - AD7293_ISENSE_MIN_OFFSET_CH),
351 offset);
352 else if (ch <= AD7293_VOUT_MAX_OFFSET_CH)
353 return ad7293_spi_update_bits(st,
354 AD7293_REG_UNI_VOUT0_OFFSET +
355 (ch - AD7293_VOUT_MIN_OFFSET_CH),
356 AD7293_REG_VOUT_OFFSET_MSK,
357 FIELD_PREP(AD7293_REG_VOUT_OFFSET_MSK, offset));
359 return -EINVAL;
362 static int ad7293_isense_set_scale(struct ad7293_state *st, unsigned int ch,
363 u16 gain)
365 unsigned int ch_msk = (0xf << (4 * ch));
367 return ad7293_spi_update_bits(st, AD7293_REG_ISENSE_GAIN, ch_msk,
368 gain << (4 * ch));
371 static int ad7293_isense_get_scale(struct ad7293_state *st, unsigned int ch,
372 u16 *gain)
374 int ret;
376 ret = ad7293_spi_read(st, AD7293_REG_ISENSE_GAIN, gain);
377 if (ret)
378 return ret;
380 *gain = (*gain >> (4 * ch)) & 0xf;
382 return ret;
385 static int ad7293_dac_write_raw(struct ad7293_state *st, unsigned int ch,
386 u16 raw)
388 int ret;
390 mutex_lock(&st->lock);
392 ret = __ad7293_spi_update_bits(st, AD7293_REG_DAC_EN, BIT(ch), BIT(ch));
393 if (ret)
394 goto exit;
396 ret = __ad7293_spi_write(st, AD7293_REG_UNI_VOUT0 + ch,
397 FIELD_PREP(AD7293_REG_DATA_RAW_MSK, raw));
399 exit:
400 mutex_unlock(&st->lock);
402 return ret;
405 static int ad7293_ch_read_raw(struct ad7293_state *st, enum ad7293_ch_type type,
406 unsigned int ch, u16 *raw)
408 int ret;
409 unsigned int reg_wr, reg_rd, data_wr;
411 switch (type) {
412 case AD7293_ADC_VINX:
413 reg_wr = AD7293_REG_VINX_SEQ;
414 reg_rd = AD7293_REG_VIN0 + ch;
415 data_wr = BIT(ch);
417 break;
418 case AD7293_ADC_TSENSE:
419 reg_wr = AD7293_REG_ISENSEX_TSENSEX_SEQ;
420 reg_rd = AD7293_REG_TSENSE_INT + ch;
421 data_wr = BIT(ch);
423 break;
424 case AD7293_ADC_ISENSE:
425 reg_wr = AD7293_REG_ISENSEX_TSENSEX_SEQ;
426 reg_rd = AD7293_REG_ISENSE_0 + ch;
427 data_wr = BIT(ch) << 8;
429 break;
430 case AD7293_DAC:
431 reg_rd = AD7293_REG_UNI_VOUT0 + ch;
433 break;
434 default:
435 return -EINVAL;
438 mutex_lock(&st->lock);
440 if (type != AD7293_DAC) {
441 if (type == AD7293_ADC_TSENSE) {
442 ret = __ad7293_spi_write(st, AD7293_REG_TSENSE_BG_EN,
443 BIT(ch));
444 if (ret)
445 goto exit;
447 usleep_range(9000, 9900);
448 } else if (type == AD7293_ADC_ISENSE) {
449 ret = __ad7293_spi_write(st, AD7293_REG_ISENSE_BG_EN,
450 BIT(ch));
451 if (ret)
452 goto exit;
454 usleep_range(2000, 7000);
457 ret = __ad7293_spi_write(st, reg_wr, data_wr);
458 if (ret)
459 goto exit;
461 ret = __ad7293_spi_write(st, AD7293_REG_CONV_CMD, 0x82);
462 if (ret)
463 goto exit;
466 ret = __ad7293_spi_read(st, reg_rd, raw);
468 *raw = FIELD_GET(AD7293_REG_DATA_RAW_MSK, *raw);
470 exit:
471 mutex_unlock(&st->lock);
473 return ret;
476 static int ad7293_read_raw(struct iio_dev *indio_dev,
477 struct iio_chan_spec const *chan,
478 int *val, int *val2, long info)
480 struct ad7293_state *st = iio_priv(indio_dev);
481 int ret;
482 u16 data;
484 switch (info) {
485 case IIO_CHAN_INFO_RAW:
486 switch (chan->type) {
487 case IIO_VOLTAGE:
488 if (chan->output)
489 ret = ad7293_ch_read_raw(st, AD7293_DAC,
490 chan->channel, &data);
491 else
492 ret = ad7293_ch_read_raw(st, AD7293_ADC_VINX,
493 chan->channel, &data);
495 break;
496 case IIO_CURRENT:
497 ret = ad7293_ch_read_raw(st, AD7293_ADC_ISENSE,
498 chan->channel, &data);
500 break;
501 case IIO_TEMP:
502 ret = ad7293_ch_read_raw(st, AD7293_ADC_TSENSE,
503 chan->channel, &data);
505 break;
506 default:
507 return -EINVAL;
510 if (ret)
511 return ret;
513 *val = data;
515 return IIO_VAL_INT;
516 case IIO_CHAN_INFO_OFFSET:
517 switch (chan->type) {
518 case IIO_VOLTAGE:
519 if (chan->output) {
520 ret = ad7293_get_offset(st,
521 chan->channel + AD7293_VOUT_MIN_OFFSET_CH,
522 &data);
524 data = FIELD_GET(AD7293_REG_VOUT_OFFSET_MSK, data);
525 } else {
526 ret = ad7293_get_offset(st, chan->channel, &data);
529 break;
530 case IIO_CURRENT:
531 ret = ad7293_get_offset(st,
532 chan->channel + AD7293_ISENSE_MIN_OFFSET_CH,
533 &data);
535 break;
536 case IIO_TEMP:
537 ret = ad7293_get_offset(st,
538 chan->channel + AD7293_TSENSE_MIN_OFFSET_CH,
539 &data);
541 break;
542 default:
543 return -EINVAL;
545 if (ret)
546 return ret;
548 *val = data;
550 return IIO_VAL_INT;
551 case IIO_CHAN_INFO_SCALE:
552 switch (chan->type) {
553 case IIO_VOLTAGE:
554 ret = ad7293_adc_get_scale(st, chan->channel, &data);
555 if (ret)
556 return ret;
558 *val = data;
560 return IIO_VAL_INT;
561 case IIO_CURRENT:
562 ret = ad7293_isense_get_scale(st, chan->channel, &data);
563 if (ret)
564 return ret;
566 *val = data;
568 return IIO_VAL_INT;
569 case IIO_TEMP:
570 *val = 1;
571 *val2 = 8;
573 return IIO_VAL_FRACTIONAL;
574 default:
575 return -EINVAL;
577 default:
578 return -EINVAL;
582 static int ad7293_write_raw(struct iio_dev *indio_dev,
583 struct iio_chan_spec const *chan,
584 int val, int val2, long info)
586 struct ad7293_state *st = iio_priv(indio_dev);
588 switch (info) {
589 case IIO_CHAN_INFO_RAW:
590 switch (chan->type) {
591 case IIO_VOLTAGE:
592 if (!chan->output)
593 return -EINVAL;
595 return ad7293_dac_write_raw(st, chan->channel, val);
596 default:
597 return -EINVAL;
599 case IIO_CHAN_INFO_OFFSET:
600 switch (chan->type) {
601 case IIO_VOLTAGE:
602 if (chan->output)
603 return ad7293_set_offset(st,
604 chan->channel +
605 AD7293_VOUT_MIN_OFFSET_CH,
606 val);
607 else
608 return ad7293_set_offset(st, chan->channel, val);
609 case IIO_CURRENT:
610 return ad7293_set_offset(st,
611 chan->channel +
612 AD7293_ISENSE_MIN_OFFSET_CH,
613 val);
614 case IIO_TEMP:
615 return ad7293_set_offset(st,
616 chan->channel +
617 AD7293_TSENSE_MIN_OFFSET_CH,
618 val);
619 default:
620 return -EINVAL;
622 case IIO_CHAN_INFO_SCALE:
623 switch (chan->type) {
624 case IIO_VOLTAGE:
625 return ad7293_adc_set_scale(st, chan->channel, val);
626 case IIO_CURRENT:
627 return ad7293_isense_set_scale(st, chan->channel, val);
628 default:
629 return -EINVAL;
631 default:
632 return -EINVAL;
636 static int ad7293_reg_access(struct iio_dev *indio_dev,
637 unsigned int reg,
638 unsigned int write_val,
639 unsigned int *read_val)
641 struct ad7293_state *st = iio_priv(indio_dev);
642 int ret;
644 if (read_val) {
645 u16 temp;
646 ret = ad7293_spi_read(st, reg, &temp);
647 *read_val = temp;
648 } else {
649 ret = ad7293_spi_write(st, reg, (u16)write_val);
652 return ret;
655 static int ad7293_read_avail(struct iio_dev *indio_dev,
656 struct iio_chan_spec const *chan,
657 const int **vals, int *type, int *length,
658 long info)
660 switch (info) {
661 case IIO_CHAN_INFO_OFFSET:
662 *vals = dac_offset_table;
663 *type = IIO_VAL_INT;
664 *length = ARRAY_SIZE(dac_offset_table);
666 return IIO_AVAIL_LIST;
667 case IIO_CHAN_INFO_SCALE:
668 *type = IIO_VAL_INT;
670 switch (chan->type) {
671 case IIO_VOLTAGE:
672 *vals = adc_range_table;
673 *length = ARRAY_SIZE(adc_range_table);
674 return IIO_AVAIL_LIST;
675 case IIO_CURRENT:
676 *vals = isense_gain_table;
677 *length = ARRAY_SIZE(isense_gain_table);
678 return IIO_AVAIL_LIST;
679 default:
680 return -EINVAL;
682 default:
683 return -EINVAL;
687 #define AD7293_CHAN_ADC(_channel) { \
688 .type = IIO_VOLTAGE, \
689 .output = 0, \
690 .indexed = 1, \
691 .channel = _channel, \
692 .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) | \
693 BIT(IIO_CHAN_INFO_SCALE) | \
694 BIT(IIO_CHAN_INFO_OFFSET), \
695 .info_mask_shared_by_type_available = BIT(IIO_CHAN_INFO_SCALE) \
698 #define AD7293_CHAN_DAC(_channel) { \
699 .type = IIO_VOLTAGE, \
700 .output = 1, \
701 .indexed = 1, \
702 .channel = _channel, \
703 .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) | \
704 BIT(IIO_CHAN_INFO_OFFSET), \
705 .info_mask_shared_by_type_available = BIT(IIO_CHAN_INFO_OFFSET) \
708 #define AD7293_CHAN_ISENSE(_channel) { \
709 .type = IIO_CURRENT, \
710 .output = 0, \
711 .indexed = 1, \
712 .channel = _channel, \
713 .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) | \
714 BIT(IIO_CHAN_INFO_OFFSET) | \
715 BIT(IIO_CHAN_INFO_SCALE), \
716 .info_mask_shared_by_type_available = BIT(IIO_CHAN_INFO_SCALE) \
719 #define AD7293_CHAN_TEMP(_channel) { \
720 .type = IIO_TEMP, \
721 .output = 0, \
722 .indexed = 1, \
723 .channel = _channel, \
724 .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) | \
725 BIT(IIO_CHAN_INFO_OFFSET), \
726 .info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE) \
729 static const struct iio_chan_spec ad7293_channels[] = {
730 AD7293_CHAN_ADC(0),
731 AD7293_CHAN_ADC(1),
732 AD7293_CHAN_ADC(2),
733 AD7293_CHAN_ADC(3),
734 AD7293_CHAN_ISENSE(0),
735 AD7293_CHAN_ISENSE(1),
736 AD7293_CHAN_ISENSE(2),
737 AD7293_CHAN_ISENSE(3),
738 AD7293_CHAN_TEMP(0),
739 AD7293_CHAN_TEMP(1),
740 AD7293_CHAN_TEMP(2),
741 AD7293_CHAN_DAC(0),
742 AD7293_CHAN_DAC(1),
743 AD7293_CHAN_DAC(2),
744 AD7293_CHAN_DAC(3),
745 AD7293_CHAN_DAC(4),
746 AD7293_CHAN_DAC(5),
747 AD7293_CHAN_DAC(6),
748 AD7293_CHAN_DAC(7)
751 static int ad7293_soft_reset(struct ad7293_state *st)
753 int ret;
755 ret = __ad7293_spi_write(st, AD7293_REG_SOFT_RESET, 0x7293);
756 if (ret)
757 return ret;
759 return __ad7293_spi_write(st, AD7293_REG_SOFT_RESET, 0x0000);
762 static int ad7293_reset(struct ad7293_state *st)
764 if (st->gpio_reset) {
765 gpiod_set_value(st->gpio_reset, 0);
766 usleep_range(100, 1000);
767 gpiod_set_value(st->gpio_reset, 1);
768 usleep_range(100, 1000);
770 return 0;
773 /* Perform a software reset */
774 return ad7293_soft_reset(st);
777 static int ad7293_properties_parse(struct ad7293_state *st)
779 struct spi_device *spi = st->spi;
781 st->gpio_reset = devm_gpiod_get_optional(&st->spi->dev, "reset",
782 GPIOD_OUT_HIGH);
783 if (IS_ERR(st->gpio_reset))
784 return dev_err_probe(&spi->dev, PTR_ERR(st->gpio_reset),
785 "failed to get the reset GPIO\n");
787 st->reg_avdd = devm_regulator_get(&spi->dev, "avdd");
788 if (IS_ERR(st->reg_avdd))
789 return dev_err_probe(&spi->dev, PTR_ERR(st->reg_avdd),
790 "failed to get the AVDD voltage\n");
792 st->reg_vdrive = devm_regulator_get(&spi->dev, "vdrive");
793 if (IS_ERR(st->reg_vdrive))
794 return dev_err_probe(&spi->dev, PTR_ERR(st->reg_vdrive),
795 "failed to get the VDRIVE voltage\n");
797 return 0;
800 static void ad7293_reg_disable(void *data)
802 regulator_disable(data);
805 static int ad7293_init(struct ad7293_state *st)
807 int ret;
808 u16 chip_id;
809 struct spi_device *spi = st->spi;
811 ret = ad7293_properties_parse(st);
812 if (ret)
813 return ret;
815 ret = ad7293_reset(st);
816 if (ret)
817 return ret;
819 ret = regulator_enable(st->reg_avdd);
820 if (ret) {
821 dev_err(&spi->dev,
822 "Failed to enable specified AVDD Voltage!\n");
823 return ret;
826 ret = devm_add_action_or_reset(&spi->dev, ad7293_reg_disable,
827 st->reg_avdd);
828 if (ret)
829 return ret;
831 ret = regulator_enable(st->reg_vdrive);
832 if (ret) {
833 dev_err(&spi->dev,
834 "Failed to enable specified VDRIVE Voltage!\n");
835 return ret;
838 ret = devm_add_action_or_reset(&spi->dev, ad7293_reg_disable,
839 st->reg_vdrive);
840 if (ret)
841 return ret;
843 ret = regulator_get_voltage(st->reg_avdd);
844 if (ret < 0) {
845 dev_err(&spi->dev, "Failed to read avdd regulator: %d\n", ret);
846 return ret;
849 if (ret > 5500000 || ret < 4500000)
850 return -EINVAL;
852 ret = regulator_get_voltage(st->reg_vdrive);
853 if (ret < 0) {
854 dev_err(&spi->dev,
855 "Failed to read vdrive regulator: %d\n", ret);
856 return ret;
858 if (ret > 5500000 || ret < 1700000)
859 return -EINVAL;
861 /* Check Chip ID */
862 ret = __ad7293_spi_read(st, AD7293_REG_DEVICE_ID, &chip_id);
863 if (ret)
864 return ret;
866 if (chip_id != AD7293_CHIP_ID) {
867 dev_err(&spi->dev, "Invalid Chip ID.\n");
868 return -EINVAL;
871 return 0;
874 static const struct iio_info ad7293_info = {
875 .read_raw = ad7293_read_raw,
876 .write_raw = ad7293_write_raw,
877 .read_avail = &ad7293_read_avail,
878 .debugfs_reg_access = &ad7293_reg_access,
881 static int ad7293_probe(struct spi_device *spi)
883 struct iio_dev *indio_dev;
884 struct ad7293_state *st;
885 int ret;
887 indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st));
888 if (!indio_dev)
889 return -ENOMEM;
891 st = iio_priv(indio_dev);
893 indio_dev->info = &ad7293_info;
894 indio_dev->name = "ad7293";
895 indio_dev->channels = ad7293_channels;
896 indio_dev->num_channels = ARRAY_SIZE(ad7293_channels);
898 st->spi = spi;
899 st->page_select = 0;
901 mutex_init(&st->lock);
903 ret = ad7293_init(st);
904 if (ret)
905 return ret;
907 return devm_iio_device_register(&spi->dev, indio_dev);
910 static const struct spi_device_id ad7293_id[] = {
911 { "ad7293", 0 },
914 MODULE_DEVICE_TABLE(spi, ad7293_id);
916 static const struct of_device_id ad7293_of_match[] = {
917 { .compatible = "adi,ad7293" },
920 MODULE_DEVICE_TABLE(of, ad7293_of_match);
922 static struct spi_driver ad7293_driver = {
923 .driver = {
924 .name = "ad7293",
925 .of_match_table = ad7293_of_match,
927 .probe = ad7293_probe,
928 .id_table = ad7293_id,
930 module_spi_driver(ad7293_driver);
932 MODULE_AUTHOR("Antoniu Miclaus <antoniu.miclaus@analog.com");
933 MODULE_DESCRIPTION("Analog Devices AD7293");
934 MODULE_LICENSE("GPL v2");