xref: /linux/drivers/iio/dac/ad5761.c (revision d97e2634fbdcd238a51bc363267df0139c17f4da)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * AD5721, AD5721R, AD5761, AD5761R, Voltage Output Digital to Analog Converter
4  *
5  * Copyright 2016 Qtechnology A/S
6  * 2016 Ricardo Ribalda <ribalda@kernel.org>
7  */
8 #include <linux/kernel.h>
9 #include <linux/module.h>
10 #include <linux/spi/spi.h>
11 #include <linux/bitops.h>
12 #include <linux/iio/iio.h>
13 #include <linux/iio/sysfs.h>
14 #include <linux/regulator/consumer.h>
15 #include <linux/platform_data/ad5761.h>
16 
17 #define AD5761_ADDR(addr)		((addr & 0xf) << 16)
18 #define AD5761_ADDR_NOOP		0x0
19 #define AD5761_ADDR_DAC_WRITE		0x3
20 #define AD5761_ADDR_CTRL_WRITE_REG	0x4
21 #define AD5761_ADDR_SW_DATA_RESET	0x7
22 #define AD5761_ADDR_DAC_READ		0xb
23 #define AD5761_ADDR_CTRL_READ_REG	0xc
24 #define AD5761_ADDR_SW_FULL_RESET	0xf
25 
26 #define AD5761_CTRL_USE_INTVREF		BIT(5)
27 #define AD5761_CTRL_ETS			BIT(6)
28 
29 /**
30  * struct ad5761_chip_info - chip specific information
31  * @int_vref:	Value of the internal reference voltage in mV - 0 if external
32  *		reference voltage is used
33  * @channel:	channel specification
34 */
35 
36 struct ad5761_chip_info {
37 	unsigned long int_vref;
38 	const struct iio_chan_spec channel;
39 };
40 
41 struct ad5761_range_params {
42 	int m;
43 	int c;
44 };
45 
46 enum ad5761_supported_device_ids {
47 	ID_AD5721,
48 	ID_AD5721R,
49 	ID_AD5761,
50 	ID_AD5761R,
51 };
52 
53 /**
54  * struct ad5761_state - driver instance specific data
55  * @spi:		spi_device
56  * @use_intref:		true when the internal voltage reference is used
57  * @vref:		actual voltage reference in mVolts
58  * @range:		output range mode used
59  * @lock:		lock to protect the data buffer during SPI ops
60  * @data:		cache aligned spi buffer
61  */
62 struct ad5761_state {
63 	struct spi_device		*spi;
64 	struct mutex			lock;
65 
66 	bool use_intref;
67 	int vref;
68 	enum ad5761_voltage_range range;
69 
70 	/*
71 	 * DMA (thus cache coherency maintenance) may require the
72 	 * transfer buffers to live in their own cache lines.
73 	 */
74 	union {
75 		__be32 d32;
76 		u8 d8[4];
77 	} data[3] __aligned(IIO_DMA_MINALIGN);
78 };
79 
80 static const struct ad5761_range_params ad5761_range_params[] = {
81 	[AD5761_VOLTAGE_RANGE_M10V_10V] = {
82 		.m = 80,
83 		.c = 40,
84 	},
85 	[AD5761_VOLTAGE_RANGE_0V_10V] = {
86 		.m = 40,
87 		.c = 0,
88 	},
89 	[AD5761_VOLTAGE_RANGE_M5V_5V] = {
90 		.m = 40,
91 		.c = 20,
92 	},
93 	[AD5761_VOLTAGE_RANGE_0V_5V] = {
94 		.m = 20,
95 		.c = 0,
96 	},
97 	[AD5761_VOLTAGE_RANGE_M2V5_7V5] = {
98 		.m = 40,
99 		.c = 10,
100 	},
101 	[AD5761_VOLTAGE_RANGE_M3V_3V] = {
102 		.m = 24,
103 		.c = 12,
104 	},
105 	[AD5761_VOLTAGE_RANGE_0V_16V] = {
106 		.m = 64,
107 		.c = 0,
108 	},
109 	[AD5761_VOLTAGE_RANGE_0V_20V] = {
110 		.m = 80,
111 		.c = 0,
112 	},
113 };
114 
115 static int _ad5761_spi_write(struct ad5761_state *st, u8 addr, u16 val)
116 {
117 	st->data[0].d32 = cpu_to_be32(AD5761_ADDR(addr) | val);
118 
119 	return spi_write(st->spi, &st->data[0].d8[1], 3);
120 }
121 
122 static int ad5761_spi_write(struct iio_dev *indio_dev, u8 addr, u16 val)
123 {
124 	struct ad5761_state *st = iio_priv(indio_dev);
125 	int ret;
126 
127 	mutex_lock(&st->lock);
128 	ret = _ad5761_spi_write(st, addr, val);
129 	mutex_unlock(&st->lock);
130 
131 	return ret;
132 }
133 
134 static int _ad5761_spi_read(struct ad5761_state *st, u8 addr, u16 *val)
135 {
136 	int ret;
137 	struct spi_transfer xfers[] = {
138 		{
139 			.tx_buf = &st->data[0].d8[1],
140 			.bits_per_word = 8,
141 			.len = 3,
142 			.cs_change = true,
143 		}, {
144 			.tx_buf = &st->data[1].d8[1],
145 			.rx_buf = &st->data[2].d8[1],
146 			.bits_per_word = 8,
147 			.len = 3,
148 		},
149 	};
150 
151 	st->data[0].d32 = cpu_to_be32(AD5761_ADDR(addr));
152 	st->data[1].d32 = cpu_to_be32(AD5761_ADDR(AD5761_ADDR_NOOP));
153 
154 	ret = spi_sync_transfer(st->spi, xfers, ARRAY_SIZE(xfers));
155 
156 	*val = be32_to_cpu(st->data[2].d32);
157 
158 	return ret;
159 }
160 
161 static int ad5761_spi_read(struct iio_dev *indio_dev, u8 addr, u16 *val)
162 {
163 	struct ad5761_state *st = iio_priv(indio_dev);
164 	int ret;
165 
166 	mutex_lock(&st->lock);
167 	ret = _ad5761_spi_read(st, addr, val);
168 	mutex_unlock(&st->lock);
169 
170 	return ret;
171 }
172 
173 static int ad5761_spi_set_range(struct ad5761_state *st,
174 				enum ad5761_voltage_range range)
175 {
176 	u16 aux;
177 	int ret;
178 
179 	aux = (range & 0x7) | AD5761_CTRL_ETS;
180 
181 	if (st->use_intref)
182 		aux |= AD5761_CTRL_USE_INTVREF;
183 
184 	ret = _ad5761_spi_write(st, AD5761_ADDR_SW_FULL_RESET, 0);
185 	if (ret)
186 		return ret;
187 
188 	ret = _ad5761_spi_write(st, AD5761_ADDR_CTRL_WRITE_REG, aux);
189 	if (ret)
190 		return ret;
191 
192 	st->range = range;
193 
194 	return 0;
195 }
196 
197 static int ad5761_read_raw(struct iio_dev *indio_dev,
198 			   struct iio_chan_spec const *chan,
199 			   int *val,
200 			   int *val2,
201 			   long mask)
202 {
203 	struct ad5761_state *st;
204 	int ret;
205 	u16 aux;
206 
207 	switch (mask) {
208 	case IIO_CHAN_INFO_RAW:
209 		ret = ad5761_spi_read(indio_dev, AD5761_ADDR_DAC_READ, &aux);
210 		if (ret)
211 			return ret;
212 		*val = aux >> chan->scan_type.shift;
213 		return IIO_VAL_INT;
214 	case IIO_CHAN_INFO_SCALE:
215 		st = iio_priv(indio_dev);
216 		*val = st->vref * ad5761_range_params[st->range].m;
217 		*val /= 10;
218 		*val2 = chan->scan_type.realbits;
219 		return IIO_VAL_FRACTIONAL_LOG2;
220 	case IIO_CHAN_INFO_OFFSET:
221 		st = iio_priv(indio_dev);
222 		*val = -(1 << chan->scan_type.realbits);
223 		*val *=	ad5761_range_params[st->range].c;
224 		*val /=	ad5761_range_params[st->range].m;
225 		return IIO_VAL_INT;
226 	default:
227 		return -EINVAL;
228 	}
229 }
230 
231 static int ad5761_write_raw(struct iio_dev *indio_dev,
232 			    struct iio_chan_spec const *chan,
233 			    int val,
234 			    int val2,
235 			    long mask)
236 {
237 	u16 aux;
238 
239 	if (mask != IIO_CHAN_INFO_RAW)
240 		return -EINVAL;
241 
242 	if (val2 || (val << chan->scan_type.shift) > 0xffff || val < 0)
243 		return -EINVAL;
244 
245 	aux = val << chan->scan_type.shift;
246 
247 	return ad5761_spi_write(indio_dev, AD5761_ADDR_DAC_WRITE, aux);
248 }
249 
250 static const struct iio_info ad5761_info = {
251 	.read_raw = &ad5761_read_raw,
252 	.write_raw = &ad5761_write_raw,
253 };
254 
255 #define AD5761_CHAN(_bits) {				\
256 	.type = IIO_VOLTAGE,				\
257 	.output = 1,					\
258 	.info_mask_separate = BIT(IIO_CHAN_INFO_RAW),	\
259 	.info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE) |	\
260 		BIT(IIO_CHAN_INFO_OFFSET),		\
261 	.scan_type = {					\
262 		.sign = 'u',				\
263 		.realbits = (_bits),			\
264 		.storagebits = 16,			\
265 		.shift = 16 - (_bits),			\
266 	},						\
267 }
268 
269 static const struct ad5761_chip_info ad5761_chip_infos[] = {
270 	[ID_AD5721] = {
271 		.int_vref = 0,
272 		.channel = AD5761_CHAN(12),
273 	},
274 	[ID_AD5721R] = {
275 		.int_vref = 2500,
276 		.channel = AD5761_CHAN(12),
277 	},
278 	[ID_AD5761] = {
279 		.int_vref = 0,
280 		.channel = AD5761_CHAN(16),
281 	},
282 	[ID_AD5761R] = {
283 		.int_vref = 2500,
284 		.channel = AD5761_CHAN(16),
285 	},
286 };
287 
288 static int ad5761_probe(struct spi_device *spi)
289 {
290 	struct iio_dev *iio_dev;
291 	struct ad5761_state *st;
292 	int ret;
293 	const struct ad5761_chip_info *chip_info =
294 		&ad5761_chip_infos[spi_get_device_id(spi)->driver_data];
295 	enum ad5761_voltage_range voltage_range = AD5761_VOLTAGE_RANGE_0V_5V;
296 	struct ad5761_platform_data *pdata = dev_get_platdata(&spi->dev);
297 
298 	iio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st));
299 	if (!iio_dev)
300 		return -ENOMEM;
301 
302 	st = iio_priv(iio_dev);
303 
304 	st->spi = spi;
305 
306 	ret = devm_regulator_get_enable_read_voltage(&spi->dev, "vref");
307 	if (ret < 0 && ret != -ENODEV)
308 		return dev_err_probe(&spi->dev, ret,
309 			"Failed to get voltage reference value\n");
310 	if (ret == -ENODEV) {
311 		/* Use Internal regulator */
312 		if (!chip_info->int_vref)
313 			return dev_err_probe(&spi->dev, -EIO,
314 				"Voltage reference not found\n");
315 
316 		st->use_intref = true;
317 		st->vref = chip_info->int_vref;
318 	} else {
319 		if (ret < 2000000 || ret > 3000000)
320 			return dev_err_probe(&spi->dev, -EIO,
321 				 "Invalid external voltage ref. value %d uV\n",
322 				 ret);
323 
324 		st->use_intref = false;
325 		st->vref = ret / 1000;
326 	}
327 
328 	if (pdata)
329 		voltage_range = pdata->voltage_range;
330 
331 	mutex_init(&st->lock);
332 
333 	ret = ad5761_spi_set_range(st, voltage_range);
334 	if (ret)
335 		return ret;
336 
337 	iio_dev->info = &ad5761_info;
338 	iio_dev->modes = INDIO_DIRECT_MODE;
339 	iio_dev->channels = &chip_info->channel;
340 	iio_dev->num_channels = 1;
341 	iio_dev->name = spi_get_device_id(st->spi)->name;
342 
343 	return devm_iio_device_register(&spi->dev, iio_dev);
344 }
345 
346 static const struct spi_device_id ad5761_id[] = {
347 	{"ad5721", ID_AD5721},
348 	{"ad5721r", ID_AD5721R},
349 	{"ad5761", ID_AD5761},
350 	{"ad5761r", ID_AD5761R},
351 	{}
352 };
353 MODULE_DEVICE_TABLE(spi, ad5761_id);
354 
355 static struct spi_driver ad5761_driver = {
356 	.driver = {
357 		   .name = "ad5761",
358 		   },
359 	.probe = ad5761_probe,
360 	.id_table = ad5761_id,
361 };
362 module_spi_driver(ad5761_driver);
363 
364 MODULE_AUTHOR("Ricardo Ribalda <ribalda@kernel.org>");
365 MODULE_DESCRIPTION("Analog Devices AD5721, AD5721R, AD5761, AD5761R driver");
366 MODULE_LICENSE("GPL v2");
367