1 // SPDX-License-Identifier: GPL-2.0
2 /*
3 * Driver for NXP FXAS21002C Gyroscope - Core
4 *
5 * Copyright (C) 2019 Linaro Ltd.
6 */
7
8 #include <linux/interrupt.h>
9 #include <linux/module.h>
10 #include <linux/of_irq.h>
11 #include <linux/pm.h>
12 #include <linux/pm_runtime.h>
13 #include <linux/regmap.h>
14 #include <linux/regulator/consumer.h>
15
16 #include <linux/iio/events.h>
17 #include <linux/iio/iio.h>
18 #include <linux/iio/buffer.h>
19 #include <linux/iio/sysfs.h>
20 #include <linux/iio/trigger.h>
21 #include <linux/iio/trigger_consumer.h>
22 #include <linux/iio/triggered_buffer.h>
23
24 #include "fxas21002c.h"
25
26 #define FXAS21002C_CHIP_ID_1 0xD6
27 #define FXAS21002C_CHIP_ID_2 0xD7
28
29 enum fxas21002c_mode_state {
30 FXAS21002C_MODE_STANDBY,
31 FXAS21002C_MODE_READY,
32 FXAS21002C_MODE_ACTIVE,
33 };
34
35 #define FXAS21002C_STANDBY_ACTIVE_TIME_MS 62
36 #define FXAS21002C_READY_ACTIVE_TIME_MS 7
37
38 #define FXAS21002C_ODR_LIST_MAX 10
39
40 #define FXAS21002C_SCALE_FRACTIONAL 32
41 #define FXAS21002C_RANGE_LIMIT_DOUBLE 2000
42
43 #define FXAS21002C_AXIS_TO_REG(axis) (FXAS21002C_REG_OUT_X_MSB + ((axis) * 2))
44
45 static const int fxas21002c_odr_values[] = {
46 800, 400, 200, 100, 50, 25, 12, 12
47 };
48
49 /*
50 * These values are taken from the low-pass filter cutoff frequency calculated
51 * ODR * 0.lpf_values. So, for ODR = 800Hz with a lpf value = 0.32
52 * => LPF cutoff frequency = 800 * 0.32 = 256 Hz
53 */
54 static const int fxas21002c_lpf_values[] = {
55 32, 16, 8
56 };
57
58 /*
59 * These values are taken from the high-pass filter cutoff frequency calculated
60 * ODR * 0.0hpf_values. So, for ODR = 800Hz with a hpf value = 0.018750
61 * => HPF cutoff frequency = 800 * 0.018750 = 15 Hz
62 */
63 static const int fxas21002c_hpf_values[] = {
64 18750, 9625, 4875, 2475
65 };
66
67 static const int fxas21002c_range_values[] = {
68 4000, 2000, 1000, 500, 250
69 };
70
71 struct fxas21002c_data {
72 u8 chip_id;
73 enum fxas21002c_mode_state mode;
74 enum fxas21002c_mode_state prev_mode;
75
76 struct mutex lock; /* serialize data access */
77 struct regmap *regmap;
78 struct regmap_field *regmap_fields[F_MAX_FIELDS];
79 struct iio_trigger *dready_trig;
80 s64 timestamp;
81 int irq;
82
83 struct regulator *vdd;
84 struct regulator *vddio;
85
86 /*
87 * DMA (thus cache coherency maintenance) requires the
88 * transfer buffers to live in their own cache lines.
89 */
90 s16 buffer[8] ____cacheline_aligned;
91 };
92
93 enum fxas21002c_channel_index {
94 CHANNEL_SCAN_INDEX_X,
95 CHANNEL_SCAN_INDEX_Y,
96 CHANNEL_SCAN_INDEX_Z,
97 CHANNEL_SCAN_MAX,
98 };
99
fxas21002c_odr_hz_from_value(struct fxas21002c_data * data,u8 value)100 static int fxas21002c_odr_hz_from_value(struct fxas21002c_data *data, u8 value)
101 {
102 int odr_value_max = ARRAY_SIZE(fxas21002c_odr_values) - 1;
103
104 value = min_t(u8, value, odr_value_max);
105
106 return fxas21002c_odr_values[value];
107 }
108
fxas21002c_odr_value_from_hz(struct fxas21002c_data * data,unsigned int hz)109 static int fxas21002c_odr_value_from_hz(struct fxas21002c_data *data,
110 unsigned int hz)
111 {
112 int odr_table_size = ARRAY_SIZE(fxas21002c_odr_values);
113 int i;
114
115 for (i = 0; i < odr_table_size; i++)
116 if (fxas21002c_odr_values[i] == hz)
117 return i;
118
119 return -EINVAL;
120 }
121
fxas21002c_lpf_bw_from_value(struct fxas21002c_data * data,u8 value)122 static int fxas21002c_lpf_bw_from_value(struct fxas21002c_data *data, u8 value)
123 {
124 int lpf_value_max = ARRAY_SIZE(fxas21002c_lpf_values) - 1;
125
126 value = min_t(u8, value, lpf_value_max);
127
128 return fxas21002c_lpf_values[value];
129 }
130
fxas21002c_lpf_value_from_bw(struct fxas21002c_data * data,unsigned int hz)131 static int fxas21002c_lpf_value_from_bw(struct fxas21002c_data *data,
132 unsigned int hz)
133 {
134 int lpf_table_size = ARRAY_SIZE(fxas21002c_lpf_values);
135 int i;
136
137 for (i = 0; i < lpf_table_size; i++)
138 if (fxas21002c_lpf_values[i] == hz)
139 return i;
140
141 return -EINVAL;
142 }
143
fxas21002c_hpf_sel_from_value(struct fxas21002c_data * data,u8 value)144 static int fxas21002c_hpf_sel_from_value(struct fxas21002c_data *data, u8 value)
145 {
146 int hpf_value_max = ARRAY_SIZE(fxas21002c_hpf_values) - 1;
147
148 value = min_t(u8, value, hpf_value_max);
149
150 return fxas21002c_hpf_values[value];
151 }
152
fxas21002c_hpf_value_from_sel(struct fxas21002c_data * data,unsigned int hz)153 static int fxas21002c_hpf_value_from_sel(struct fxas21002c_data *data,
154 unsigned int hz)
155 {
156 int hpf_table_size = ARRAY_SIZE(fxas21002c_hpf_values);
157 int i;
158
159 for (i = 0; i < hpf_table_size; i++)
160 if (fxas21002c_hpf_values[i] == hz)
161 return i;
162
163 return -EINVAL;
164 }
165
fxas21002c_range_fs_from_value(struct fxas21002c_data * data,u8 value)166 static int fxas21002c_range_fs_from_value(struct fxas21002c_data *data,
167 u8 value)
168 {
169 int range_value_max = ARRAY_SIZE(fxas21002c_range_values) - 1;
170 unsigned int fs_double;
171 int ret;
172
173 /* We need to check if FS_DOUBLE is enabled to offset the value */
174 ret = regmap_field_read(data->regmap_fields[F_FS_DOUBLE], &fs_double);
175 if (ret < 0)
176 return ret;
177
178 if (!fs_double)
179 value += 1;
180
181 value = min_t(u8, value, range_value_max);
182
183 return fxas21002c_range_values[value];
184 }
185
fxas21002c_range_value_from_fs(struct fxas21002c_data * data,unsigned int range)186 static int fxas21002c_range_value_from_fs(struct fxas21002c_data *data,
187 unsigned int range)
188 {
189 int range_table_size = ARRAY_SIZE(fxas21002c_range_values);
190 bool found = false;
191 int fs_double = 0;
192 int ret;
193 int i;
194
195 for (i = 0; i < range_table_size; i++)
196 if (fxas21002c_range_values[i] == range) {
197 found = true;
198 break;
199 }
200
201 if (!found)
202 return -EINVAL;
203
204 if (range > FXAS21002C_RANGE_LIMIT_DOUBLE)
205 fs_double = 1;
206
207 ret = regmap_field_write(data->regmap_fields[F_FS_DOUBLE], fs_double);
208 if (ret < 0)
209 return ret;
210
211 return i;
212 }
213
fxas21002c_mode_get(struct fxas21002c_data * data)214 static int fxas21002c_mode_get(struct fxas21002c_data *data)
215 {
216 unsigned int active;
217 unsigned int ready;
218 int ret;
219
220 ret = regmap_field_read(data->regmap_fields[F_ACTIVE], &active);
221 if (ret < 0)
222 return ret;
223 if (active)
224 return FXAS21002C_MODE_ACTIVE;
225
226 ret = regmap_field_read(data->regmap_fields[F_READY], &ready);
227 if (ret < 0)
228 return ret;
229 if (ready)
230 return FXAS21002C_MODE_READY;
231
232 return FXAS21002C_MODE_STANDBY;
233 }
234
fxas21002c_mode_set(struct fxas21002c_data * data,enum fxas21002c_mode_state mode)235 static int fxas21002c_mode_set(struct fxas21002c_data *data,
236 enum fxas21002c_mode_state mode)
237 {
238 int ret;
239
240 if (mode == data->mode)
241 return 0;
242
243 if (mode == FXAS21002C_MODE_READY)
244 ret = regmap_field_write(data->regmap_fields[F_READY], 1);
245 else
246 ret = regmap_field_write(data->regmap_fields[F_READY], 0);
247 if (ret < 0)
248 return ret;
249
250 if (mode == FXAS21002C_MODE_ACTIVE)
251 ret = regmap_field_write(data->regmap_fields[F_ACTIVE], 1);
252 else
253 ret = regmap_field_write(data->regmap_fields[F_ACTIVE], 0);
254 if (ret < 0)
255 return ret;
256
257 /* if going to active wait the setup times */
258 if (mode == FXAS21002C_MODE_ACTIVE &&
259 data->mode == FXAS21002C_MODE_STANDBY)
260 msleep_interruptible(FXAS21002C_STANDBY_ACTIVE_TIME_MS);
261
262 if (data->mode == FXAS21002C_MODE_READY)
263 msleep_interruptible(FXAS21002C_READY_ACTIVE_TIME_MS);
264
265 data->prev_mode = data->mode;
266 data->mode = mode;
267
268 return ret;
269 }
270
fxas21002c_write(struct fxas21002c_data * data,enum fxas21002c_fields field,int bits)271 static int fxas21002c_write(struct fxas21002c_data *data,
272 enum fxas21002c_fields field, int bits)
273 {
274 int actual_mode;
275 int ret;
276
277 mutex_lock(&data->lock);
278
279 actual_mode = fxas21002c_mode_get(data);
280 if (actual_mode < 0) {
281 ret = actual_mode;
282 goto out_unlock;
283 }
284
285 ret = fxas21002c_mode_set(data, FXAS21002C_MODE_READY);
286 if (ret < 0)
287 goto out_unlock;
288
289 ret = regmap_field_write(data->regmap_fields[field], bits);
290 if (ret < 0)
291 goto out_unlock;
292
293 ret = fxas21002c_mode_set(data, data->prev_mode);
294
295 out_unlock:
296 mutex_unlock(&data->lock);
297
298 return ret;
299 }
300
fxas21002c_pm_get(struct fxas21002c_data * data)301 static int fxas21002c_pm_get(struct fxas21002c_data *data)
302 {
303 struct device *dev = regmap_get_device(data->regmap);
304 int ret;
305
306 ret = pm_runtime_get_sync(dev);
307 if (ret < 0)
308 pm_runtime_put_noidle(dev);
309
310 return ret;
311 }
312
fxas21002c_pm_put(struct fxas21002c_data * data)313 static int fxas21002c_pm_put(struct fxas21002c_data *data)
314 {
315 struct device *dev = regmap_get_device(data->regmap);
316
317 pm_runtime_mark_last_busy(dev);
318
319 return pm_runtime_put_autosuspend(dev);
320 }
321
fxas21002c_temp_get(struct fxas21002c_data * data,int * val)322 static int fxas21002c_temp_get(struct fxas21002c_data *data, int *val)
323 {
324 struct device *dev = regmap_get_device(data->regmap);
325 unsigned int temp;
326 int ret;
327
328 mutex_lock(&data->lock);
329 ret = fxas21002c_pm_get(data);
330 if (ret < 0)
331 goto data_unlock;
332
333 ret = regmap_field_read(data->regmap_fields[F_TEMP], &temp);
334 if (ret < 0) {
335 dev_err(dev, "failed to read temp: %d\n", ret);
336 goto data_unlock;
337 }
338
339 *val = sign_extend32(temp, 7);
340
341 ret = fxas21002c_pm_put(data);
342 if (ret < 0)
343 goto data_unlock;
344
345 ret = IIO_VAL_INT;
346
347 data_unlock:
348 mutex_unlock(&data->lock);
349
350 return ret;
351 }
352
fxas21002c_axis_get(struct fxas21002c_data * data,int index,int * val)353 static int fxas21002c_axis_get(struct fxas21002c_data *data,
354 int index, int *val)
355 {
356 struct device *dev = regmap_get_device(data->regmap);
357 __be16 axis_be;
358 int ret;
359
360 mutex_lock(&data->lock);
361 ret = fxas21002c_pm_get(data);
362 if (ret < 0)
363 goto data_unlock;
364
365 ret = regmap_bulk_read(data->regmap, FXAS21002C_AXIS_TO_REG(index),
366 &axis_be, sizeof(axis_be));
367 if (ret < 0) {
368 dev_err(dev, "failed to read axis: %d: %d\n", index, ret);
369 goto data_unlock;
370 }
371
372 *val = sign_extend32(be16_to_cpu(axis_be), 15);
373
374 ret = fxas21002c_pm_put(data);
375 if (ret < 0)
376 goto data_unlock;
377
378 ret = IIO_VAL_INT;
379
380 data_unlock:
381 mutex_unlock(&data->lock);
382
383 return ret;
384 }
385
fxas21002c_odr_get(struct fxas21002c_data * data,int * odr)386 static int fxas21002c_odr_get(struct fxas21002c_data *data, int *odr)
387 {
388 unsigned int odr_bits;
389 int ret;
390
391 mutex_lock(&data->lock);
392 ret = regmap_field_read(data->regmap_fields[F_DR], &odr_bits);
393 if (ret < 0)
394 goto data_unlock;
395
396 *odr = fxas21002c_odr_hz_from_value(data, odr_bits);
397
398 ret = IIO_VAL_INT;
399
400 data_unlock:
401 mutex_unlock(&data->lock);
402
403 return ret;
404 }
405
fxas21002c_odr_set(struct fxas21002c_data * data,int odr)406 static int fxas21002c_odr_set(struct fxas21002c_data *data, int odr)
407 {
408 int odr_bits;
409
410 odr_bits = fxas21002c_odr_value_from_hz(data, odr);
411 if (odr_bits < 0)
412 return odr_bits;
413
414 return fxas21002c_write(data, F_DR, odr_bits);
415 }
416
fxas21002c_lpf_get(struct fxas21002c_data * data,int * val2)417 static int fxas21002c_lpf_get(struct fxas21002c_data *data, int *val2)
418 {
419 unsigned int bw_bits;
420 int ret;
421
422 mutex_lock(&data->lock);
423 ret = regmap_field_read(data->regmap_fields[F_BW], &bw_bits);
424 if (ret < 0)
425 goto data_unlock;
426
427 *val2 = fxas21002c_lpf_bw_from_value(data, bw_bits) * 10000;
428
429 ret = IIO_VAL_INT_PLUS_MICRO;
430
431 data_unlock:
432 mutex_unlock(&data->lock);
433
434 return ret;
435 }
436
fxas21002c_lpf_set(struct fxas21002c_data * data,int bw)437 static int fxas21002c_lpf_set(struct fxas21002c_data *data, int bw)
438 {
439 int bw_bits;
440 int odr;
441 int ret;
442
443 bw_bits = fxas21002c_lpf_value_from_bw(data, bw);
444 if (bw_bits < 0)
445 return bw_bits;
446
447 /*
448 * From table 33 of the device spec, for ODR = 25Hz and 12.5 value 0.08
449 * is not allowed and for ODR = 12.5 value 0.16 is also not allowed
450 */
451 ret = fxas21002c_odr_get(data, &odr);
452 if (ret < 0)
453 return -EINVAL;
454
455 if ((odr == 25 && bw_bits > 0x01) || (odr == 12 && bw_bits > 0))
456 return -EINVAL;
457
458 return fxas21002c_write(data, F_BW, bw_bits);
459 }
460
fxas21002c_hpf_get(struct fxas21002c_data * data,int * val2)461 static int fxas21002c_hpf_get(struct fxas21002c_data *data, int *val2)
462 {
463 unsigned int sel_bits;
464 int ret;
465
466 mutex_lock(&data->lock);
467 ret = regmap_field_read(data->regmap_fields[F_SEL], &sel_bits);
468 if (ret < 0)
469 goto data_unlock;
470
471 *val2 = fxas21002c_hpf_sel_from_value(data, sel_bits);
472
473 ret = IIO_VAL_INT_PLUS_MICRO;
474
475 data_unlock:
476 mutex_unlock(&data->lock);
477
478 return ret;
479 }
480
fxas21002c_hpf_set(struct fxas21002c_data * data,int sel)481 static int fxas21002c_hpf_set(struct fxas21002c_data *data, int sel)
482 {
483 int sel_bits;
484
485 sel_bits = fxas21002c_hpf_value_from_sel(data, sel);
486 if (sel_bits < 0)
487 return sel_bits;
488
489 return fxas21002c_write(data, F_SEL, sel_bits);
490 }
491
fxas21002c_scale_get(struct fxas21002c_data * data,int * val)492 static int fxas21002c_scale_get(struct fxas21002c_data *data, int *val)
493 {
494 int fs_bits;
495 int scale;
496 int ret;
497
498 mutex_lock(&data->lock);
499 ret = regmap_field_read(data->regmap_fields[F_FS], &fs_bits);
500 if (ret < 0)
501 goto data_unlock;
502
503 scale = fxas21002c_range_fs_from_value(data, fs_bits);
504 if (scale < 0) {
505 ret = scale;
506 goto data_unlock;
507 }
508
509 *val = scale;
510
511 data_unlock:
512 mutex_unlock(&data->lock);
513
514 return ret;
515 }
516
fxas21002c_scale_set(struct fxas21002c_data * data,int range)517 static int fxas21002c_scale_set(struct fxas21002c_data *data, int range)
518 {
519 int fs_bits;
520
521 fs_bits = fxas21002c_range_value_from_fs(data, range);
522 if (fs_bits < 0)
523 return fs_bits;
524
525 return fxas21002c_write(data, F_FS, fs_bits);
526 }
527
fxas21002c_read_raw(struct iio_dev * indio_dev,struct iio_chan_spec const * chan,int * val,int * val2,long mask)528 static int fxas21002c_read_raw(struct iio_dev *indio_dev,
529 struct iio_chan_spec const *chan, int *val,
530 int *val2, long mask)
531 {
532 struct fxas21002c_data *data = iio_priv(indio_dev);
533 int ret;
534
535 switch (mask) {
536 case IIO_CHAN_INFO_RAW:
537 switch (chan->type) {
538 case IIO_TEMP:
539 return fxas21002c_temp_get(data, val);
540 case IIO_ANGL_VEL:
541 return fxas21002c_axis_get(data, chan->scan_index, val);
542 default:
543 return -EINVAL;
544 }
545 case IIO_CHAN_INFO_SCALE:
546 switch (chan->type) {
547 case IIO_ANGL_VEL:
548 *val2 = FXAS21002C_SCALE_FRACTIONAL;
549 ret = fxas21002c_scale_get(data, val);
550 if (ret < 0)
551 return ret;
552
553 return IIO_VAL_FRACTIONAL;
554 default:
555 return -EINVAL;
556 }
557 case IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY:
558 *val = 0;
559 return fxas21002c_lpf_get(data, val2);
560 case IIO_CHAN_INFO_HIGH_PASS_FILTER_3DB_FREQUENCY:
561 *val = 0;
562 return fxas21002c_hpf_get(data, val2);
563 case IIO_CHAN_INFO_SAMP_FREQ:
564 *val2 = 0;
565 return fxas21002c_odr_get(data, val);
566 default:
567 return -EINVAL;
568 }
569 }
570
fxas21002c_write_raw(struct iio_dev * indio_dev,struct iio_chan_spec const * chan,int val,int val2,long mask)571 static int fxas21002c_write_raw(struct iio_dev *indio_dev,
572 struct iio_chan_spec const *chan, int val,
573 int val2, long mask)
574 {
575 struct fxas21002c_data *data = iio_priv(indio_dev);
576 int range;
577
578 switch (mask) {
579 case IIO_CHAN_INFO_SAMP_FREQ:
580 if (val2)
581 return -EINVAL;
582
583 return fxas21002c_odr_set(data, val);
584 case IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY:
585 if (val)
586 return -EINVAL;
587
588 val2 = val2 / 10000;
589 return fxas21002c_lpf_set(data, val2);
590 case IIO_CHAN_INFO_SCALE:
591 switch (chan->type) {
592 case IIO_ANGL_VEL:
593 range = (((val * 1000 + val2 / 1000) *
594 FXAS21002C_SCALE_FRACTIONAL) / 1000);
595 return fxas21002c_scale_set(data, range);
596 default:
597 return -EINVAL;
598 }
599 case IIO_CHAN_INFO_HIGH_PASS_FILTER_3DB_FREQUENCY:
600 return fxas21002c_hpf_set(data, val2);
601 default:
602 return -EINVAL;
603 }
604 }
605
606 static IIO_CONST_ATTR_SAMP_FREQ_AVAIL("12.5 25 50 100 200 400 800");
607
608 static IIO_CONST_ATTR(in_anglvel_filter_low_pass_3db_frequency_available,
609 "0.32 0.16 0.08");
610
611 static IIO_CONST_ATTR(in_anglvel_filter_high_pass_3db_frequency_available,
612 "0.018750 0.009625 0.004875 0.002475");
613
614 static IIO_CONST_ATTR(in_anglvel_scale_available,
615 "125.0 62.5 31.25 15.625 7.8125");
616
617 static struct attribute *fxas21002c_attributes[] = {
618 &iio_const_attr_sampling_frequency_available.dev_attr.attr,
619 &iio_const_attr_in_anglvel_filter_low_pass_3db_frequency_available.dev_attr.attr,
620 &iio_const_attr_in_anglvel_filter_high_pass_3db_frequency_available.dev_attr.attr,
621 &iio_const_attr_in_anglvel_scale_available.dev_attr.attr,
622 NULL,
623 };
624
625 static const struct attribute_group fxas21002c_attrs_group = {
626 .attrs = fxas21002c_attributes,
627 };
628
629 #define FXAS21002C_CHANNEL(_axis) { \
630 .type = IIO_ANGL_VEL, \
631 .modified = 1, \
632 .channel2 = IIO_MOD_##_axis, \
633 .info_mask_separate = BIT(IIO_CHAN_INFO_RAW), \
634 .info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE) | \
635 BIT(IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY) | \
636 BIT(IIO_CHAN_INFO_HIGH_PASS_FILTER_3DB_FREQUENCY) | \
637 BIT(IIO_CHAN_INFO_SAMP_FREQ), \
638 .scan_index = CHANNEL_SCAN_INDEX_##_axis, \
639 .scan_type = { \
640 .sign = 's', \
641 .realbits = 16, \
642 .storagebits = 16, \
643 .endianness = IIO_BE, \
644 }, \
645 }
646
647 static const struct iio_chan_spec fxas21002c_channels[] = {
648 {
649 .type = IIO_TEMP,
650 .info_mask_separate = BIT(IIO_CHAN_INFO_RAW),
651 .scan_index = -1,
652 },
653 FXAS21002C_CHANNEL(X),
654 FXAS21002C_CHANNEL(Y),
655 FXAS21002C_CHANNEL(Z),
656 };
657
658 static const struct iio_info fxas21002c_info = {
659 .attrs = &fxas21002c_attrs_group,
660 .read_raw = &fxas21002c_read_raw,
661 .write_raw = &fxas21002c_write_raw,
662 };
663
fxas21002c_trigger_handler(int irq,void * p)664 static irqreturn_t fxas21002c_trigger_handler(int irq, void *p)
665 {
666 struct iio_poll_func *pf = p;
667 struct iio_dev *indio_dev = pf->indio_dev;
668 struct fxas21002c_data *data = iio_priv(indio_dev);
669 int ret;
670
671 mutex_lock(&data->lock);
672 ret = regmap_bulk_read(data->regmap, FXAS21002C_REG_OUT_X_MSB,
673 data->buffer, CHANNEL_SCAN_MAX * sizeof(s16));
674 if (ret < 0)
675 goto out_unlock;
676
677 iio_push_to_buffers_with_timestamp(indio_dev, data->buffer,
678 data->timestamp);
679
680 out_unlock:
681 mutex_unlock(&data->lock);
682
683 iio_trigger_notify_done(indio_dev->trig);
684
685 return IRQ_HANDLED;
686 }
687
fxas21002c_chip_init(struct fxas21002c_data * data)688 static int fxas21002c_chip_init(struct fxas21002c_data *data)
689 {
690 struct device *dev = regmap_get_device(data->regmap);
691 unsigned int chip_id;
692 int ret;
693
694 ret = regmap_field_read(data->regmap_fields[F_WHO_AM_I], &chip_id);
695 if (ret < 0)
696 return ret;
697
698 if (chip_id != FXAS21002C_CHIP_ID_1 &&
699 chip_id != FXAS21002C_CHIP_ID_2) {
700 dev_err(dev, "chip id 0x%02x is not supported\n", chip_id);
701 return -EINVAL;
702 }
703
704 data->chip_id = chip_id;
705
706 ret = fxas21002c_mode_set(data, FXAS21002C_MODE_STANDBY);
707 if (ret < 0)
708 return ret;
709
710 /* Set ODR to 200HZ as default */
711 ret = fxas21002c_odr_set(data, 200);
712 if (ret < 0)
713 dev_err(dev, "failed to set ODR: %d\n", ret);
714
715 return ret;
716 }
717
fxas21002c_data_rdy_trigger_set_state(struct iio_trigger * trig,bool state)718 static int fxas21002c_data_rdy_trigger_set_state(struct iio_trigger *trig,
719 bool state)
720 {
721 struct iio_dev *indio_dev = iio_trigger_get_drvdata(trig);
722 struct fxas21002c_data *data = iio_priv(indio_dev);
723
724 return regmap_field_write(data->regmap_fields[F_INT_EN_DRDY], state);
725 }
726
727 static const struct iio_trigger_ops fxas21002c_trigger_ops = {
728 .set_trigger_state = &fxas21002c_data_rdy_trigger_set_state,
729 };
730
fxas21002c_data_rdy_handler(int irq,void * private)731 static irqreturn_t fxas21002c_data_rdy_handler(int irq, void *private)
732 {
733 struct iio_dev *indio_dev = private;
734 struct fxas21002c_data *data = iio_priv(indio_dev);
735
736 data->timestamp = iio_get_time_ns(indio_dev);
737
738 return IRQ_WAKE_THREAD;
739 }
740
fxas21002c_data_rdy_thread(int irq,void * private)741 static irqreturn_t fxas21002c_data_rdy_thread(int irq, void *private)
742 {
743 struct iio_dev *indio_dev = private;
744 struct fxas21002c_data *data = iio_priv(indio_dev);
745 unsigned int data_ready;
746 int ret;
747
748 ret = regmap_field_read(data->regmap_fields[F_SRC_DRDY], &data_ready);
749 if (ret < 0)
750 return IRQ_NONE;
751
752 if (!data_ready)
753 return IRQ_NONE;
754
755 iio_trigger_poll_chained(data->dready_trig);
756
757 return IRQ_HANDLED;
758 }
759
fxas21002c_trigger_probe(struct fxas21002c_data * data)760 static int fxas21002c_trigger_probe(struct fxas21002c_data *data)
761 {
762 struct device *dev = regmap_get_device(data->regmap);
763 struct iio_dev *indio_dev = dev_get_drvdata(dev);
764 struct device_node *np = indio_dev->dev.of_node;
765 unsigned long irq_trig;
766 bool irq_open_drain;
767 int irq1;
768 int ret;
769
770 if (!data->irq)
771 return 0;
772
773 irq1 = of_irq_get_byname(np, "INT1");
774
775 if (irq1 == data->irq) {
776 dev_info(dev, "using interrupt line INT1\n");
777 ret = regmap_field_write(data->regmap_fields[F_INT_CFG_DRDY],
778 1);
779 if (ret < 0)
780 return ret;
781 }
782
783 dev_info(dev, "using interrupt line INT2\n");
784
785 irq_open_drain = of_property_read_bool(np, "drive-open-drain");
786
787 data->dready_trig = devm_iio_trigger_alloc(dev, "%s-dev%d",
788 indio_dev->name,
789 indio_dev->id);
790 if (!data->dready_trig)
791 return -ENOMEM;
792
793 irq_trig = irqd_get_trigger_type(irq_get_irq_data(data->irq));
794
795 if (irq_trig == IRQF_TRIGGER_RISING) {
796 ret = regmap_field_write(data->regmap_fields[F_IPOL], 1);
797 if (ret < 0)
798 return ret;
799 }
800
801 if (irq_open_drain)
802 irq_trig |= IRQF_SHARED;
803
804 ret = devm_request_threaded_irq(dev, data->irq,
805 fxas21002c_data_rdy_handler,
806 fxas21002c_data_rdy_thread,
807 irq_trig, "fxas21002c_data_ready",
808 indio_dev);
809 if (ret < 0)
810 return ret;
811
812 data->dready_trig->dev.parent = dev;
813 data->dready_trig->ops = &fxas21002c_trigger_ops;
814 iio_trigger_set_drvdata(data->dready_trig, indio_dev);
815
816 return devm_iio_trigger_register(dev, data->dready_trig);
817 }
818
fxas21002c_power_enable(struct fxas21002c_data * data)819 static int fxas21002c_power_enable(struct fxas21002c_data *data)
820 {
821 int ret;
822
823 ret = regulator_enable(data->vdd);
824 if (ret < 0)
825 return ret;
826
827 ret = regulator_enable(data->vddio);
828 if (ret < 0) {
829 regulator_disable(data->vdd);
830 return ret;
831 }
832
833 return 0;
834 }
835
fxas21002c_power_disable(struct fxas21002c_data * data)836 static void fxas21002c_power_disable(struct fxas21002c_data *data)
837 {
838 regulator_disable(data->vdd);
839 regulator_disable(data->vddio);
840 }
841
fxas21002c_power_disable_action(void * _data)842 static void fxas21002c_power_disable_action(void *_data)
843 {
844 struct fxas21002c_data *data = _data;
845
846 fxas21002c_power_disable(data);
847 }
848
fxas21002c_regulators_get(struct fxas21002c_data * data)849 static int fxas21002c_regulators_get(struct fxas21002c_data *data)
850 {
851 struct device *dev = regmap_get_device(data->regmap);
852
853 data->vdd = devm_regulator_get(dev->parent, "vdd");
854 if (IS_ERR(data->vdd))
855 return PTR_ERR(data->vdd);
856
857 data->vddio = devm_regulator_get(dev->parent, "vddio");
858
859 return PTR_ERR_OR_ZERO(data->vddio);
860 }
861
fxas21002c_core_probe(struct device * dev,struct regmap * regmap,int irq,const char * name)862 int fxas21002c_core_probe(struct device *dev, struct regmap *regmap, int irq,
863 const char *name)
864 {
865 struct fxas21002c_data *data;
866 struct iio_dev *indio_dev;
867 struct regmap_field *f;
868 int i;
869 int ret;
870
871 indio_dev = devm_iio_device_alloc(dev, sizeof(*data));
872 if (!indio_dev)
873 return -ENOMEM;
874
875 data = iio_priv(indio_dev);
876 dev_set_drvdata(dev, indio_dev);
877 data->irq = irq;
878 data->regmap = regmap;
879
880 for (i = 0; i < F_MAX_FIELDS; i++) {
881 f = devm_regmap_field_alloc(dev, data->regmap,
882 fxas21002c_reg_fields[i]);
883 if (IS_ERR(f))
884 return PTR_ERR(f);
885
886 data->regmap_fields[i] = f;
887 }
888
889 mutex_init(&data->lock);
890
891 ret = fxas21002c_regulators_get(data);
892 if (ret < 0)
893 return ret;
894
895 ret = fxas21002c_power_enable(data);
896 if (ret < 0)
897 return ret;
898
899 ret = devm_add_action_or_reset(dev, fxas21002c_power_disable_action,
900 data);
901 if (ret < 0)
902 return ret;
903
904 ret = fxas21002c_chip_init(data);
905 if (ret < 0)
906 return ret;
907
908 indio_dev->dev.parent = dev;
909 indio_dev->channels = fxas21002c_channels;
910 indio_dev->num_channels = ARRAY_SIZE(fxas21002c_channels);
911 indio_dev->name = name;
912 indio_dev->modes = INDIO_DIRECT_MODE;
913 indio_dev->info = &fxas21002c_info;
914
915 ret = fxas21002c_trigger_probe(data);
916 if (ret < 0)
917 return ret;
918
919 ret = devm_iio_triggered_buffer_setup(dev, indio_dev, NULL,
920 fxas21002c_trigger_handler, NULL);
921 if (ret < 0)
922 return ret;
923
924 ret = pm_runtime_set_active(dev);
925 if (ret)
926 return ret;
927
928 pm_runtime_enable(dev);
929 pm_runtime_set_autosuspend_delay(dev, 2000);
930 pm_runtime_use_autosuspend(dev);
931
932 ret = iio_device_register(indio_dev);
933 if (ret < 0)
934 goto pm_disable;
935
936 return 0;
937
938 pm_disable:
939 pm_runtime_disable(dev);
940 pm_runtime_set_suspended(dev);
941 pm_runtime_put_noidle(dev);
942
943 return ret;
944 }
945 EXPORT_SYMBOL_GPL(fxas21002c_core_probe);
946
fxas21002c_core_remove(struct device * dev)947 void fxas21002c_core_remove(struct device *dev)
948 {
949 struct iio_dev *indio_dev = dev_get_drvdata(dev);
950
951 iio_device_unregister(indio_dev);
952
953 pm_runtime_disable(dev);
954 pm_runtime_set_suspended(dev);
955 pm_runtime_put_noidle(dev);
956 }
957 EXPORT_SYMBOL_GPL(fxas21002c_core_remove);
958
fxas21002c_suspend(struct device * dev)959 static int __maybe_unused fxas21002c_suspend(struct device *dev)
960 {
961 struct fxas21002c_data *data = iio_priv(dev_get_drvdata(dev));
962
963 fxas21002c_mode_set(data, FXAS21002C_MODE_STANDBY);
964 fxas21002c_power_disable(data);
965
966 return 0;
967 }
968
fxas21002c_resume(struct device * dev)969 static int __maybe_unused fxas21002c_resume(struct device *dev)
970 {
971 struct fxas21002c_data *data = iio_priv(dev_get_drvdata(dev));
972 int ret;
973
974 ret = fxas21002c_power_enable(data);
975 if (ret < 0)
976 return ret;
977
978 return fxas21002c_mode_set(data, data->prev_mode);
979 }
980
fxas21002c_runtime_suspend(struct device * dev)981 static int __maybe_unused fxas21002c_runtime_suspend(struct device *dev)
982 {
983 struct fxas21002c_data *data = iio_priv(dev_get_drvdata(dev));
984
985 return fxas21002c_mode_set(data, FXAS21002C_MODE_READY);
986 }
987
fxas21002c_runtime_resume(struct device * dev)988 static int __maybe_unused fxas21002c_runtime_resume(struct device *dev)
989 {
990 struct fxas21002c_data *data = iio_priv(dev_get_drvdata(dev));
991
992 return fxas21002c_mode_set(data, FXAS21002C_MODE_ACTIVE);
993 }
994
995 const struct dev_pm_ops fxas21002c_pm_ops = {
996 SET_SYSTEM_SLEEP_PM_OPS(fxas21002c_suspend, fxas21002c_resume)
997 SET_RUNTIME_PM_OPS(fxas21002c_runtime_suspend,
998 fxas21002c_runtime_resume, NULL)
999 };
1000 EXPORT_SYMBOL_GPL(fxas21002c_pm_ops);
1001
1002 MODULE_AUTHOR("Rui Miguel Silva <rui.silva@linaro.org>");
1003 MODULE_LICENSE("GPL v2");
1004 MODULE_DESCRIPTION("FXAS21002C Gyro driver");
1005