1 // SPDX-License-Identifier: GPL-2.0-only
3 * AD5415, AD5426, AD5429, AD5432, AD5439, AD5443, AD5449 Digital to Analog
6 * Copyright 2012 Analog Devices Inc.
7 * Author: Lars-Peter Clausen <lars@metafoo.de>
10 #include <linux/device.h>
11 #include <linux/err.h>
12 #include <linux/module.h>
13 #include <linux/kernel.h>
14 #include <linux/spi/spi.h>
15 #include <linux/slab.h>
16 #include <linux/sysfs.h>
17 #include <linux/regulator/consumer.h>
18 #include <linux/unaligned.h>
20 #include <linux/iio/iio.h>
21 #include <linux/iio/sysfs.h>
23 #define AD5449_MAX_CHANNELS 2
24 #define AD5449_MAX_VREFS 2
26 #define AD5449_CMD_NOOP 0x0
27 #define AD5449_CMD_LOAD_AND_UPDATE(x) (0x1 + (x) * 3)
28 #define AD5449_CMD_READ(x) (0x2 + (x) * 3)
29 #define AD5449_CMD_LOAD(x) (0x3 + (x) * 3)
30 #define AD5449_CMD_CTRL 13
32 #define AD5449_CTRL_SDO_OFFSET 10
33 #define AD5449_CTRL_DAISY_CHAIN BIT(9)
34 #define AD5449_CTRL_HCLR_TO_MIDSCALE BIT(8)
35 #define AD5449_CTRL_SAMPLE_RISING BIT(7)
38 * struct ad5449_chip_info - chip specific information
39 * @channels: Channel specification
40 * @num_channels: Number of channels
41 * @has_ctrl: Chip has a control register
43 struct ad5449_chip_info
{
44 const struct iio_chan_spec
*channels
;
45 unsigned int num_channels
;
50 * struct ad5449 - driver instance specific data
51 * @spi: the SPI device for this driver instance
52 * @chip_info: chip model specific constants, available modes etc
53 * @vref_reg: vref supply regulators
54 * @has_sdo: whether the SDO line is connected
55 * @dac_cache: Cache for the DAC values
56 * @data: spi transfer buffers
57 * @lock: lock to protect the data buffer during SPI ops
60 struct spi_device
*spi
;
61 const struct ad5449_chip_info
*chip_info
;
62 struct regulator_bulk_data vref_reg
[AD5449_MAX_VREFS
];
66 uint16_t dac_cache
[AD5449_MAX_CHANNELS
];
69 * DMA (thus cache coherency maintenance) may require the
70 * transfer buffers to live in their own cache lines.
72 __be16 data
[2] __aligned(IIO_DMA_MINALIGN
);
84 static int ad5449_write(struct iio_dev
*indio_dev
, unsigned int addr
,
87 struct ad5449
*st
= iio_priv(indio_dev
);
90 mutex_lock(&st
->lock
);
91 st
->data
[0] = cpu_to_be16((addr
<< 12) | val
);
92 ret
= spi_write(st
->spi
, st
->data
, 2);
93 mutex_unlock(&st
->lock
);
98 static int ad5449_read(struct iio_dev
*indio_dev
, unsigned int addr
,
101 struct ad5449
*st
= iio_priv(indio_dev
);
103 struct spi_transfer t
[] = {
105 .tx_buf
= &st
->data
[0],
109 .tx_buf
= &st
->data
[1],
110 .rx_buf
= &st
->data
[1],
115 mutex_lock(&st
->lock
);
116 st
->data
[0] = cpu_to_be16(addr
<< 12);
117 st
->data
[1] = cpu_to_be16(AD5449_CMD_NOOP
);
119 ret
= spi_sync_transfer(st
->spi
, t
, ARRAY_SIZE(t
));
123 *val
= be16_to_cpu(st
->data
[1]);
126 mutex_unlock(&st
->lock
);
130 static int ad5449_read_raw(struct iio_dev
*indio_dev
,
131 struct iio_chan_spec
const *chan
, int *val
, int *val2
, long info
)
133 struct ad5449
*st
= iio_priv(indio_dev
);
134 struct regulator_bulk_data
*reg
;
139 case IIO_CHAN_INFO_RAW
:
141 ret
= ad5449_read(indio_dev
,
142 AD5449_CMD_READ(chan
->address
), val
);
147 *val
= st
->dac_cache
[chan
->address
];
151 case IIO_CHAN_INFO_SCALE
:
152 reg
= &st
->vref_reg
[chan
->channel
];
153 scale_uv
= regulator_get_voltage(reg
->consumer
);
157 *val
= scale_uv
/ 1000;
158 *val2
= chan
->scan_type
.realbits
;
160 return IIO_VAL_FRACTIONAL_LOG2
;
168 static int ad5449_write_raw(struct iio_dev
*indio_dev
,
169 struct iio_chan_spec
const *chan
, int val
, int val2
, long info
)
171 struct ad5449
*st
= iio_priv(indio_dev
);
175 case IIO_CHAN_INFO_RAW
:
176 if (val
< 0 || val
>= (1 << chan
->scan_type
.realbits
))
179 ret
= ad5449_write(indio_dev
,
180 AD5449_CMD_LOAD_AND_UPDATE(chan
->address
),
181 val
<< chan
->scan_type
.shift
);
183 st
->dac_cache
[chan
->address
] = val
;
192 static const struct iio_info ad5449_info
= {
193 .read_raw
= ad5449_read_raw
,
194 .write_raw
= ad5449_write_raw
,
197 #define AD5449_CHANNEL(chan, bits) { \
198 .type = IIO_VOLTAGE, \
202 .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) | \
203 BIT(IIO_CHAN_INFO_SCALE), \
207 .realbits = (bits), \
209 .shift = 12 - (bits), \
213 #define DECLARE_AD5449_CHANNELS(name, bits) \
214 const struct iio_chan_spec name[] = { \
215 AD5449_CHANNEL(0, bits), \
216 AD5449_CHANNEL(1, bits), \
219 static DECLARE_AD5449_CHANNELS(ad5429_channels
, 8);
220 static DECLARE_AD5449_CHANNELS(ad5439_channels
, 10);
221 static DECLARE_AD5449_CHANNELS(ad5449_channels
, 12);
223 static const struct ad5449_chip_info ad5449_chip_info
[] = {
225 .channels
= ad5429_channels
,
230 .channels
= ad5429_channels
,
235 .channels
= ad5439_channels
,
240 .channels
= ad5439_channels
,
245 .channels
= ad5449_channels
,
250 .channels
= ad5449_channels
,
256 static const char *ad5449_vref_name(struct ad5449
*st
, int n
)
258 if (st
->chip_info
->num_channels
== 1)
267 static int ad5449_spi_probe(struct spi_device
*spi
)
269 const struct spi_device_id
*id
= spi_get_device_id(spi
);
270 struct iio_dev
*indio_dev
;
275 indio_dev
= devm_iio_device_alloc(&spi
->dev
, sizeof(*st
));
276 if (indio_dev
== NULL
)
279 st
= iio_priv(indio_dev
);
280 spi_set_drvdata(spi
, indio_dev
);
282 st
->chip_info
= &ad5449_chip_info
[id
->driver_data
];
285 for (i
= 0; i
< st
->chip_info
->num_channels
; ++i
)
286 st
->vref_reg
[i
].supply
= ad5449_vref_name(st
, i
);
288 ret
= devm_regulator_bulk_get(&spi
->dev
, st
->chip_info
->num_channels
,
293 ret
= regulator_bulk_enable(st
->chip_info
->num_channels
, st
->vref_reg
);
297 indio_dev
->name
= id
->name
;
298 indio_dev
->info
= &ad5449_info
;
299 indio_dev
->modes
= INDIO_DIRECT_MODE
;
300 indio_dev
->channels
= st
->chip_info
->channels
;
301 indio_dev
->num_channels
= st
->chip_info
->num_channels
;
303 mutex_init(&st
->lock
);
305 if (st
->chip_info
->has_ctrl
) {
307 ad5449_write(indio_dev
, AD5449_CMD_CTRL
, 0x0);
310 ret
= iio_device_register(indio_dev
);
312 goto error_disable_reg
;
317 regulator_bulk_disable(st
->chip_info
->num_channels
, st
->vref_reg
);
322 static void ad5449_spi_remove(struct spi_device
*spi
)
324 struct iio_dev
*indio_dev
= spi_get_drvdata(spi
);
325 struct ad5449
*st
= iio_priv(indio_dev
);
327 iio_device_unregister(indio_dev
);
329 regulator_bulk_disable(st
->chip_info
->num_channels
, st
->vref_reg
);
332 static const struct spi_device_id ad5449_spi_ids
[] = {
333 { "ad5415", ID_AD5449
},
334 { "ad5426", ID_AD5426
},
335 { "ad5429", ID_AD5429
},
336 { "ad5432", ID_AD5432
},
337 { "ad5439", ID_AD5439
},
338 { "ad5443", ID_AD5443
},
339 { "ad5449", ID_AD5449
},
342 MODULE_DEVICE_TABLE(spi
, ad5449_spi_ids
);
344 static struct spi_driver ad5449_spi_driver
= {
348 .probe
= ad5449_spi_probe
,
349 .remove
= ad5449_spi_remove
,
350 .id_table
= ad5449_spi_ids
,
352 module_spi_driver(ad5449_spi_driver
);
354 MODULE_AUTHOR("Lars-Peter Clausen <lars@metafoo.de>");
355 MODULE_DESCRIPTION("Analog Devices AD5449 and similar DACs");
356 MODULE_LICENSE("GPL v2");