1/*
2 * ADXRS450/ADXRS453 Digital Output Gyroscope Driver
3 *
4 * Copyright 2011 Analog Devices Inc.
5 *
6 * Licensed under the GPL-2.
7 */
8
9#include <linux/interrupt.h>
10#include <linux/irq.h>
11#include <linux/delay.h>
12#include <linux/mutex.h>
13#include <linux/device.h>
14#include <linux/kernel.h>
15#include <linux/spi/spi.h>
16#include <linux/slab.h>
17#include <linux/sysfs.h>
18#include <linux/list.h>
19#include <linux/module.h>
20
21#include <linux/iio/iio.h>
22#include <linux/iio/sysfs.h>
23
24#define ADXRS450_STARTUP_DELAY	50 /* ms */
25
26/* The MSB for the spi commands */
27#define ADXRS450_SENSOR_DATA    (0x20 << 24)
28#define ADXRS450_WRITE_DATA	(0x40 << 24)
29#define ADXRS450_READ_DATA	(0x80 << 24)
30
31#define ADXRS450_RATE1	0x00	/* Rate Registers */
32#define ADXRS450_TEMP1	0x02	/* Temperature Registers */
33#define ADXRS450_LOCST1	0x04	/* Low CST Memory Registers */
34#define ADXRS450_HICST1	0x06	/* High CST Memory Registers */
35#define ADXRS450_QUAD1	0x08	/* Quad Memory Registers */
36#define ADXRS450_FAULT1	0x0A	/* Fault Registers */
37#define ADXRS450_PID1	0x0C	/* Part ID Register 1 */
38#define ADXRS450_SNH	0x0E	/* Serial Number Registers, 4 bytes */
39#define ADXRS450_SNL	0x10
40#define ADXRS450_DNC1	0x12	/* Dynamic Null Correction Registers */
41/* Check bits */
42#define ADXRS450_P	0x01
43#define ADXRS450_CHK	0x02
44#define ADXRS450_CST	0x04
45#define ADXRS450_PWR	0x08
46#define ADXRS450_POR	0x10
47#define ADXRS450_NVM	0x20
48#define ADXRS450_Q	0x40
49#define ADXRS450_PLL	0x80
50#define ADXRS450_UV	0x100
51#define ADXRS450_OV	0x200
52#define ADXRS450_AMP	0x400
53#define ADXRS450_FAIL	0x800
54
55#define ADXRS450_WRERR_MASK	(0x7 << 29)
56
57#define ADXRS450_MAX_RX 4
58#define ADXRS450_MAX_TX 4
59
60#define ADXRS450_GET_ST(a)	((a >> 26) & 0x3)
61
62enum {
63	ID_ADXRS450,
64	ID_ADXRS453,
65};
66
67/**
68 * struct adxrs450_state - device instance specific data
69 * @us:			actual spi_device
70 * @buf_lock:		mutex to protect tx and rx
71 * @tx:			transmit buffer
72 * @rx:			receive buffer
73 **/
74struct adxrs450_state {
75	struct spi_device	*us;
76	struct mutex		buf_lock;
77	__be32			tx ____cacheline_aligned;
78	__be32			rx;
79
80};
81
82/**
83 * adxrs450_spi_read_reg_16() - read 2 bytes from a register pair
84 * @indio_dev: device associated with child of actual iio_dev
85 * @reg_address: the address of the lower of the two registers, which should be
86 *	an even address, the second register's address is reg_address + 1.
87 * @val: somewhere to pass back the value read
88 **/
89static int adxrs450_spi_read_reg_16(struct iio_dev *indio_dev,
90				    u8 reg_address,
91				    u16 *val)
92{
93	struct adxrs450_state *st = iio_priv(indio_dev);
94	u32 tx;
95	int ret;
96	struct spi_transfer xfers[] = {
97		{
98			.tx_buf = &st->tx,
99			.bits_per_word = 8,
100			.len = sizeof(st->tx),
101			.cs_change = 1,
102		}, {
103			.rx_buf = &st->rx,
104			.bits_per_word = 8,
105			.len = sizeof(st->rx),
106		},
107	};
108
109	mutex_lock(&st->buf_lock);
110	tx = ADXRS450_READ_DATA | (reg_address << 17);
111
112	if (!(hweight32(tx) & 1))
113		tx |= ADXRS450_P;
114
115	st->tx = cpu_to_be32(tx);
116	ret = spi_sync_transfer(st->us, xfers, ARRAY_SIZE(xfers));
117	if (ret) {
118		dev_err(&st->us->dev, "problem while reading 16 bit register 0x%02x\n",
119				reg_address);
120		goto error_ret;
121	}
122
123	*val = (be32_to_cpu(st->rx) >> 5) & 0xFFFF;
124
125error_ret:
126	mutex_unlock(&st->buf_lock);
127	return ret;
128}
129
130/**
131 * adxrs450_spi_write_reg_16() - write 2 bytes data to a register pair
132 * @indio_dev: device associated with child of actual actual iio_dev
133 * @reg_address: the address of the lower of the two registers,which should be
134 *	an even address, the second register's address is reg_address + 1.
135 * @val: value to be written.
136 **/
137static int adxrs450_spi_write_reg_16(struct iio_dev *indio_dev,
138				     u8 reg_address,
139				     u16 val)
140{
141	struct adxrs450_state *st = iio_priv(indio_dev);
142	u32 tx;
143	int ret;
144
145	mutex_lock(&st->buf_lock);
146	tx = ADXRS450_WRITE_DATA | (reg_address << 17) | (val << 1);
147
148	if (!(hweight32(tx) & 1))
149		tx |= ADXRS450_P;
150
151	st->tx = cpu_to_be32(tx);
152	ret = spi_write(st->us, &st->tx, sizeof(st->tx));
153	if (ret)
154		dev_err(&st->us->dev, "problem while writing 16 bit register 0x%02x\n",
155			reg_address);
156	usleep_range(100, 1000); /* enforce sequential transfer delay 0.1ms */
157	mutex_unlock(&st->buf_lock);
158	return ret;
159}
160
161/**
162 * adxrs450_spi_sensor_data() - read 2 bytes sensor data
163 * @indio_dev: device associated with child of actual iio_dev
164 * @val: somewhere to pass back the value read
165 **/
166static int adxrs450_spi_sensor_data(struct iio_dev *indio_dev, s16 *val)
167{
168	struct adxrs450_state *st = iio_priv(indio_dev);
169	int ret;
170	struct spi_transfer xfers[] = {
171		{
172			.tx_buf = &st->tx,
173			.bits_per_word = 8,
174			.len = sizeof(st->tx),
175			.cs_change = 1,
176		}, {
177			.rx_buf = &st->rx,
178			.bits_per_word = 8,
179			.len = sizeof(st->rx),
180		},
181	};
182
183	mutex_lock(&st->buf_lock);
184	st->tx = cpu_to_be32(ADXRS450_SENSOR_DATA);
185
186	ret = spi_sync_transfer(st->us, xfers, ARRAY_SIZE(xfers));
187	if (ret) {
188		dev_err(&st->us->dev, "Problem while reading sensor data\n");
189		goto error_ret;
190	}
191
192	*val = (be32_to_cpu(st->rx) >> 10) & 0xFFFF;
193
194error_ret:
195	mutex_unlock(&st->buf_lock);
196	return ret;
197}
198
199/**
200 * adxrs450_spi_initial() - use for initializing procedure.
201 * @st: device instance specific data
202 * @val: somewhere to pass back the value read
203 * @chk: Whether to perform fault check
204 **/
205static int adxrs450_spi_initial(struct adxrs450_state *st,
206		u32 *val, char chk)
207{
208	int ret;
209	u32 tx;
210	struct spi_transfer xfers = {
211		.tx_buf = &st->tx,
212		.rx_buf = &st->rx,
213		.bits_per_word = 8,
214		.len = sizeof(st->tx),
215	};
216
217	mutex_lock(&st->buf_lock);
218	tx = ADXRS450_SENSOR_DATA;
219	if (chk)
220		tx |= (ADXRS450_CHK | ADXRS450_P);
221	st->tx = cpu_to_be32(tx);
222	ret = spi_sync_transfer(st->us, &xfers, 1);
223	if (ret) {
224		dev_err(&st->us->dev, "Problem while reading initializing data\n");
225		goto error_ret;
226	}
227
228	*val = be32_to_cpu(st->rx);
229
230error_ret:
231	mutex_unlock(&st->buf_lock);
232	return ret;
233}
234
235/* Recommended Startup Sequence by spec */
236static int adxrs450_initial_setup(struct iio_dev *indio_dev)
237{
238	u32 t;
239	u16 data;
240	int ret;
241	struct adxrs450_state *st = iio_priv(indio_dev);
242
243	msleep(ADXRS450_STARTUP_DELAY*2);
244	ret = adxrs450_spi_initial(st, &t, 1);
245	if (ret)
246		return ret;
247	if (t != 0x01)
248		dev_warn(&st->us->dev, "The initial power on response is not correct! Restart without reset?\n");
249
250	msleep(ADXRS450_STARTUP_DELAY);
251	ret = adxrs450_spi_initial(st, &t, 0);
252	if (ret)
253		return ret;
254
255	msleep(ADXRS450_STARTUP_DELAY);
256	ret = adxrs450_spi_initial(st, &t, 0);
257	if (ret)
258		return ret;
259	if (((t & 0xff) | 0x01) != 0xff || ADXRS450_GET_ST(t) != 2) {
260		dev_err(&st->us->dev, "The second response is not correct!\n");
261		return -EIO;
262
263	}
264	ret = adxrs450_spi_initial(st, &t, 0);
265	if (ret)
266		return ret;
267	if (((t & 0xff) | 0x01) != 0xff || ADXRS450_GET_ST(t) != 2) {
268		dev_err(&st->us->dev, "The third response is not correct!\n");
269		return -EIO;
270
271	}
272	ret = adxrs450_spi_read_reg_16(indio_dev, ADXRS450_FAULT1, &data);
273	if (ret)
274		return ret;
275	if (data & 0x0fff) {
276		dev_err(&st->us->dev, "The device is not in normal status!\n");
277		return -EINVAL;
278	}
279
280	return 0;
281}
282
283static int adxrs450_write_raw(struct iio_dev *indio_dev,
284			      struct iio_chan_spec const *chan,
285			      int val,
286			      int val2,
287			      long mask)
288{
289	int ret;
290	switch (mask) {
291	case IIO_CHAN_INFO_CALIBBIAS:
292		if (val < -0x400 || val >= 0x400)
293			return -EINVAL;
294		ret = adxrs450_spi_write_reg_16(indio_dev,
295						ADXRS450_DNC1, val);
296		break;
297	default:
298		ret = -EINVAL;
299		break;
300	}
301	return ret;
302}
303
304static int adxrs450_read_raw(struct iio_dev *indio_dev,
305			     struct iio_chan_spec const *chan,
306			     int *val,
307			     int *val2,
308			     long mask)
309{
310	int ret;
311	s16 t;
312
313	switch (mask) {
314	case IIO_CHAN_INFO_RAW:
315		switch (chan->type) {
316		case IIO_ANGL_VEL:
317			ret = adxrs450_spi_sensor_data(indio_dev, &t);
318			if (ret)
319				break;
320			*val = t;
321			ret = IIO_VAL_INT;
322			break;
323		case IIO_TEMP:
324			ret = adxrs450_spi_read_reg_16(indio_dev,
325						       ADXRS450_TEMP1, &t);
326			if (ret)
327				break;
328			*val = (t >> 6) + 225;
329			ret = IIO_VAL_INT;
330			break;
331		default:
332			ret = -EINVAL;
333			break;
334		}
335		break;
336	case IIO_CHAN_INFO_SCALE:
337		switch (chan->type) {
338		case IIO_ANGL_VEL:
339			*val = 0;
340			*val2 = 218166;
341			return IIO_VAL_INT_PLUS_NANO;
342		case IIO_TEMP:
343			*val = 200;
344			*val2 = 0;
345			return IIO_VAL_INT;
346		default:
347			return -EINVAL;
348		}
349	case IIO_CHAN_INFO_QUADRATURE_CORRECTION_RAW:
350		ret = adxrs450_spi_read_reg_16(indio_dev, ADXRS450_QUAD1, &t);
351		if (ret)
352			break;
353		*val = t;
354		ret = IIO_VAL_INT;
355		break;
356	case IIO_CHAN_INFO_CALIBBIAS:
357		ret = adxrs450_spi_read_reg_16(indio_dev, ADXRS450_DNC1, &t);
358		if (ret)
359			break;
360		*val = sign_extend32(t, 9);
361		ret = IIO_VAL_INT;
362		break;
363	default:
364		ret = -EINVAL;
365		break;
366	}
367
368	return ret;
369}
370
371static const struct iio_chan_spec adxrs450_channels[2][2] = {
372	[ID_ADXRS450] = {
373		{
374			.type = IIO_ANGL_VEL,
375			.modified = 1,
376			.channel2 = IIO_MOD_Z,
377			.info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
378			BIT(IIO_CHAN_INFO_CALIBBIAS) |
379			BIT(IIO_CHAN_INFO_QUADRATURE_CORRECTION_RAW) |
380			BIT(IIO_CHAN_INFO_SCALE),
381		}, {
382			.type = IIO_TEMP,
383			.indexed = 1,
384			.channel = 0,
385			.info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
386			BIT(IIO_CHAN_INFO_SCALE),
387		}
388	},
389	[ID_ADXRS453] = {
390		{
391			.type = IIO_ANGL_VEL,
392			.modified = 1,
393			.channel2 = IIO_MOD_Z,
394			.info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
395			BIT(IIO_CHAN_INFO_SCALE) |
396			BIT(IIO_CHAN_INFO_QUADRATURE_CORRECTION_RAW),
397		}, {
398			.type = IIO_TEMP,
399			.indexed = 1,
400			.channel = 0,
401			.info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
402			BIT(IIO_CHAN_INFO_SCALE),
403		}
404	},
405};
406
407static const struct iio_info adxrs450_info = {
408	.driver_module = THIS_MODULE,
409	.read_raw = &adxrs450_read_raw,
410	.write_raw = &adxrs450_write_raw,
411};
412
413static int adxrs450_probe(struct spi_device *spi)
414{
415	int ret;
416	struct adxrs450_state *st;
417	struct iio_dev *indio_dev;
418
419	/* setup the industrialio driver allocated elements */
420	indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st));
421	if (!indio_dev)
422		return -ENOMEM;
423	st = iio_priv(indio_dev);
424	st->us = spi;
425	mutex_init(&st->buf_lock);
426	/* This is only used for removal purposes */
427	spi_set_drvdata(spi, indio_dev);
428
429	indio_dev->dev.parent = &spi->dev;
430	indio_dev->info = &adxrs450_info;
431	indio_dev->modes = INDIO_DIRECT_MODE;
432	indio_dev->channels =
433		adxrs450_channels[spi_get_device_id(spi)->driver_data];
434	indio_dev->num_channels = ARRAY_SIZE(adxrs450_channels);
435	indio_dev->name = spi->dev.driver->name;
436
437	ret = devm_iio_device_register(&spi->dev, indio_dev);
438	if (ret)
439		return ret;
440
441	/* Get the device into a sane initial state */
442	ret = adxrs450_initial_setup(indio_dev);
443	if (ret)
444		return ret;
445
446	return 0;
447}
448
449static const struct spi_device_id adxrs450_id[] = {
450	{"adxrs450", ID_ADXRS450},
451	{"adxrs453", ID_ADXRS453},
452	{}
453};
454MODULE_DEVICE_TABLE(spi, adxrs450_id);
455
456static struct spi_driver adxrs450_driver = {
457	.driver = {
458		.name = "adxrs450",
459		.owner = THIS_MODULE,
460	},
461	.probe = adxrs450_probe,
462	.id_table	= adxrs450_id,
463};
464module_spi_driver(adxrs450_driver);
465
466MODULE_AUTHOR("Cliff Cai <cliff.cai@xxxxxxxxxx>");
467MODULE_DESCRIPTION("Analog Devices ADXRS450/ADXRS453 Gyroscope SPI driver");
468MODULE_LICENSE("GPL v2");
469