xref: /linux/drivers/iio/light/opt3001.c (revision ebf68996de0ab250c5d520eb2291ab65643e9a1e)
1 // SPDX-License-Identifier: GPL-2.0-only
2 /**
3  * opt3001.c - Texas Instruments OPT3001 Light Sensor
4  *
5  * Copyright (C) 2014 Texas Instruments Incorporated - http://www.ti.com
6  *
7  * Author: Andreas Dannenberg <dannenberg@ti.com>
8  * Based on previous work from: Felipe Balbi <balbi@ti.com>
9  */
10 
11 #include <linux/bitops.h>
12 #include <linux/delay.h>
13 #include <linux/device.h>
14 #include <linux/i2c.h>
15 #include <linux/interrupt.h>
16 #include <linux/irq.h>
17 #include <linux/kernel.h>
18 #include <linux/module.h>
19 #include <linux/mutex.h>
20 #include <linux/slab.h>
21 #include <linux/types.h>
22 
23 #include <linux/iio/events.h>
24 #include <linux/iio/iio.h>
25 #include <linux/iio/sysfs.h>
26 
27 #define OPT3001_RESULT		0x00
28 #define OPT3001_CONFIGURATION	0x01
29 #define OPT3001_LOW_LIMIT	0x02
30 #define OPT3001_HIGH_LIMIT	0x03
31 #define OPT3001_MANUFACTURER_ID	0x7e
32 #define OPT3001_DEVICE_ID	0x7f
33 
34 #define OPT3001_CONFIGURATION_RN_MASK	(0xf << 12)
35 #define OPT3001_CONFIGURATION_RN_AUTO	(0xc << 12)
36 
37 #define OPT3001_CONFIGURATION_CT	BIT(11)
38 
39 #define OPT3001_CONFIGURATION_M_MASK	(3 << 9)
40 #define OPT3001_CONFIGURATION_M_SHUTDOWN (0 << 9)
41 #define OPT3001_CONFIGURATION_M_SINGLE	(1 << 9)
42 #define OPT3001_CONFIGURATION_M_CONTINUOUS (2 << 9) /* also 3 << 9 */
43 
44 #define OPT3001_CONFIGURATION_OVF	BIT(8)
45 #define OPT3001_CONFIGURATION_CRF	BIT(7)
46 #define OPT3001_CONFIGURATION_FH	BIT(6)
47 #define OPT3001_CONFIGURATION_FL	BIT(5)
48 #define OPT3001_CONFIGURATION_L		BIT(4)
49 #define OPT3001_CONFIGURATION_POL	BIT(3)
50 #define OPT3001_CONFIGURATION_ME	BIT(2)
51 
52 #define OPT3001_CONFIGURATION_FC_MASK	(3 << 0)
53 
54 /* The end-of-conversion enable is located in the low-limit register */
55 #define OPT3001_LOW_LIMIT_EOC_ENABLE	0xc000
56 
57 #define OPT3001_REG_EXPONENT(n)		((n) >> 12)
58 #define OPT3001_REG_MANTISSA(n)		((n) & 0xfff)
59 
60 #define OPT3001_INT_TIME_LONG		800000
61 #define OPT3001_INT_TIME_SHORT		100000
62 
63 /*
64  * Time to wait for conversion result to be ready. The device datasheet
65  * sect. 6.5 states results are ready after total integration time plus 3ms.
66  * This results in worst-case max values of 113ms or 883ms, respectively.
67  * Add some slack to be on the safe side.
68  */
69 #define OPT3001_RESULT_READY_SHORT	150
70 #define OPT3001_RESULT_READY_LONG	1000
71 
72 struct opt3001 {
73 	struct i2c_client	*client;
74 	struct device		*dev;
75 
76 	struct mutex		lock;
77 	bool			ok_to_ignore_lock;
78 	bool			result_ready;
79 	wait_queue_head_t	result_ready_queue;
80 	u16			result;
81 
82 	u32			int_time;
83 	u32			mode;
84 
85 	u16			high_thresh_mantissa;
86 	u16			low_thresh_mantissa;
87 
88 	u8			high_thresh_exp;
89 	u8			low_thresh_exp;
90 
91 	bool			use_irq;
92 };
93 
94 struct opt3001_scale {
95 	int	val;
96 	int	val2;
97 };
98 
99 static const struct opt3001_scale opt3001_scales[] = {
100 	{
101 		.val = 40,
102 		.val2 = 950000,
103 	},
104 	{
105 		.val = 81,
106 		.val2 = 900000,
107 	},
108 	{
109 		.val = 163,
110 		.val2 = 800000,
111 	},
112 	{
113 		.val = 327,
114 		.val2 = 600000,
115 	},
116 	{
117 		.val = 655,
118 		.val2 = 200000,
119 	},
120 	{
121 		.val = 1310,
122 		.val2 = 400000,
123 	},
124 	{
125 		.val = 2620,
126 		.val2 = 800000,
127 	},
128 	{
129 		.val = 5241,
130 		.val2 = 600000,
131 	},
132 	{
133 		.val = 10483,
134 		.val2 = 200000,
135 	},
136 	{
137 		.val = 20966,
138 		.val2 = 400000,
139 	},
140 	{
141 		.val = 83865,
142 		.val2 = 600000,
143 	},
144 };
145 
146 static int opt3001_find_scale(const struct opt3001 *opt, int val,
147 		int val2, u8 *exponent)
148 {
149 	int i;
150 
151 	for (i = 0; i < ARRAY_SIZE(opt3001_scales); i++) {
152 		const struct opt3001_scale *scale = &opt3001_scales[i];
153 
154 		/*
155 		 * Combine the integer and micro parts for comparison
156 		 * purposes. Use milli lux precision to avoid 32-bit integer
157 		 * overflows.
158 		 */
159 		if ((val * 1000 + val2 / 1000) <=
160 				(scale->val * 1000 + scale->val2 / 1000)) {
161 			*exponent = i;
162 			return 0;
163 		}
164 	}
165 
166 	return -EINVAL;
167 }
168 
169 static void opt3001_to_iio_ret(struct opt3001 *opt, u8 exponent,
170 		u16 mantissa, int *val, int *val2)
171 {
172 	int lux;
173 
174 	lux = 10 * (mantissa << exponent);
175 	*val = lux / 1000;
176 	*val2 = (lux - (*val * 1000)) * 1000;
177 }
178 
179 static void opt3001_set_mode(struct opt3001 *opt, u16 *reg, u16 mode)
180 {
181 	*reg &= ~OPT3001_CONFIGURATION_M_MASK;
182 	*reg |= mode;
183 	opt->mode = mode;
184 }
185 
186 static IIO_CONST_ATTR_INT_TIME_AVAIL("0.1 0.8");
187 
188 static struct attribute *opt3001_attributes[] = {
189 	&iio_const_attr_integration_time_available.dev_attr.attr,
190 	NULL
191 };
192 
193 static const struct attribute_group opt3001_attribute_group = {
194 	.attrs = opt3001_attributes,
195 };
196 
197 static const struct iio_event_spec opt3001_event_spec[] = {
198 	{
199 		.type = IIO_EV_TYPE_THRESH,
200 		.dir = IIO_EV_DIR_RISING,
201 		.mask_separate = BIT(IIO_EV_INFO_VALUE) |
202 			BIT(IIO_EV_INFO_ENABLE),
203 	},
204 	{
205 		.type = IIO_EV_TYPE_THRESH,
206 		.dir = IIO_EV_DIR_FALLING,
207 		.mask_separate = BIT(IIO_EV_INFO_VALUE) |
208 			BIT(IIO_EV_INFO_ENABLE),
209 	},
210 };
211 
212 static const struct iio_chan_spec opt3001_channels[] = {
213 	{
214 		.type = IIO_LIGHT,
215 		.info_mask_separate = BIT(IIO_CHAN_INFO_PROCESSED) |
216 				BIT(IIO_CHAN_INFO_INT_TIME),
217 		.event_spec = opt3001_event_spec,
218 		.num_event_specs = ARRAY_SIZE(opt3001_event_spec),
219 	},
220 	IIO_CHAN_SOFT_TIMESTAMP(1),
221 };
222 
223 static int opt3001_get_lux(struct opt3001 *opt, int *val, int *val2)
224 {
225 	int ret;
226 	u16 mantissa;
227 	u16 reg;
228 	u8 exponent;
229 	u16 value;
230 	long timeout;
231 
232 	if (opt->use_irq) {
233 		/*
234 		 * Enable the end-of-conversion interrupt mechanism. Note that
235 		 * doing so will overwrite the low-level limit value however we
236 		 * will restore this value later on.
237 		 */
238 		ret = i2c_smbus_write_word_swapped(opt->client,
239 					OPT3001_LOW_LIMIT,
240 					OPT3001_LOW_LIMIT_EOC_ENABLE);
241 		if (ret < 0) {
242 			dev_err(opt->dev, "failed to write register %02x\n",
243 					OPT3001_LOW_LIMIT);
244 			return ret;
245 		}
246 
247 		/* Allow IRQ to access the device despite lock being set */
248 		opt->ok_to_ignore_lock = true;
249 	}
250 
251 	/* Reset data-ready indicator flag */
252 	opt->result_ready = false;
253 
254 	/* Configure for single-conversion mode and start a new conversion */
255 	ret = i2c_smbus_read_word_swapped(opt->client, OPT3001_CONFIGURATION);
256 	if (ret < 0) {
257 		dev_err(opt->dev, "failed to read register %02x\n",
258 				OPT3001_CONFIGURATION);
259 		goto err;
260 	}
261 
262 	reg = ret;
263 	opt3001_set_mode(opt, &reg, OPT3001_CONFIGURATION_M_SINGLE);
264 
265 	ret = i2c_smbus_write_word_swapped(opt->client, OPT3001_CONFIGURATION,
266 			reg);
267 	if (ret < 0) {
268 		dev_err(opt->dev, "failed to write register %02x\n",
269 				OPT3001_CONFIGURATION);
270 		goto err;
271 	}
272 
273 	if (opt->use_irq) {
274 		/* Wait for the IRQ to indicate the conversion is complete */
275 		ret = wait_event_timeout(opt->result_ready_queue,
276 				opt->result_ready,
277 				msecs_to_jiffies(OPT3001_RESULT_READY_LONG));
278 	} else {
279 		/* Sleep for result ready time */
280 		timeout = (opt->int_time == OPT3001_INT_TIME_SHORT) ?
281 			OPT3001_RESULT_READY_SHORT : OPT3001_RESULT_READY_LONG;
282 		msleep(timeout);
283 
284 		/* Check result ready flag */
285 		ret = i2c_smbus_read_word_swapped(opt->client,
286 						  OPT3001_CONFIGURATION);
287 		if (ret < 0) {
288 			dev_err(opt->dev, "failed to read register %02x\n",
289 				OPT3001_CONFIGURATION);
290 			goto err;
291 		}
292 
293 		if (!(ret & OPT3001_CONFIGURATION_CRF)) {
294 			ret = -ETIMEDOUT;
295 			goto err;
296 		}
297 
298 		/* Obtain value */
299 		ret = i2c_smbus_read_word_swapped(opt->client, OPT3001_RESULT);
300 		if (ret < 0) {
301 			dev_err(opt->dev, "failed to read register %02x\n",
302 				OPT3001_RESULT);
303 			goto err;
304 		}
305 		opt->result = ret;
306 		opt->result_ready = true;
307 	}
308 
309 err:
310 	if (opt->use_irq)
311 		/* Disallow IRQ to access the device while lock is active */
312 		opt->ok_to_ignore_lock = false;
313 
314 	if (ret == 0)
315 		return -ETIMEDOUT;
316 	else if (ret < 0)
317 		return ret;
318 
319 	if (opt->use_irq) {
320 		/*
321 		 * Disable the end-of-conversion interrupt mechanism by
322 		 * restoring the low-level limit value (clearing
323 		 * OPT3001_LOW_LIMIT_EOC_ENABLE). Note that selectively clearing
324 		 * those enable bits would affect the actual limit value due to
325 		 * bit-overlap and therefore can't be done.
326 		 */
327 		value = (opt->low_thresh_exp << 12) | opt->low_thresh_mantissa;
328 		ret = i2c_smbus_write_word_swapped(opt->client,
329 						   OPT3001_LOW_LIMIT,
330 						   value);
331 		if (ret < 0) {
332 			dev_err(opt->dev, "failed to write register %02x\n",
333 					OPT3001_LOW_LIMIT);
334 			return ret;
335 		}
336 	}
337 
338 	exponent = OPT3001_REG_EXPONENT(opt->result);
339 	mantissa = OPT3001_REG_MANTISSA(opt->result);
340 
341 	opt3001_to_iio_ret(opt, exponent, mantissa, val, val2);
342 
343 	return IIO_VAL_INT_PLUS_MICRO;
344 }
345 
346 static int opt3001_get_int_time(struct opt3001 *opt, int *val, int *val2)
347 {
348 	*val = 0;
349 	*val2 = opt->int_time;
350 
351 	return IIO_VAL_INT_PLUS_MICRO;
352 }
353 
354 static int opt3001_set_int_time(struct opt3001 *opt, int time)
355 {
356 	int ret;
357 	u16 reg;
358 
359 	ret = i2c_smbus_read_word_swapped(opt->client, OPT3001_CONFIGURATION);
360 	if (ret < 0) {
361 		dev_err(opt->dev, "failed to read register %02x\n",
362 				OPT3001_CONFIGURATION);
363 		return ret;
364 	}
365 
366 	reg = ret;
367 
368 	switch (time) {
369 	case OPT3001_INT_TIME_SHORT:
370 		reg &= ~OPT3001_CONFIGURATION_CT;
371 		opt->int_time = OPT3001_INT_TIME_SHORT;
372 		break;
373 	case OPT3001_INT_TIME_LONG:
374 		reg |= OPT3001_CONFIGURATION_CT;
375 		opt->int_time = OPT3001_INT_TIME_LONG;
376 		break;
377 	default:
378 		return -EINVAL;
379 	}
380 
381 	return i2c_smbus_write_word_swapped(opt->client, OPT3001_CONFIGURATION,
382 			reg);
383 }
384 
385 static int opt3001_read_raw(struct iio_dev *iio,
386 		struct iio_chan_spec const *chan, int *val, int *val2,
387 		long mask)
388 {
389 	struct opt3001 *opt = iio_priv(iio);
390 	int ret;
391 
392 	if (opt->mode == OPT3001_CONFIGURATION_M_CONTINUOUS)
393 		return -EBUSY;
394 
395 	if (chan->type != IIO_LIGHT)
396 		return -EINVAL;
397 
398 	mutex_lock(&opt->lock);
399 
400 	switch (mask) {
401 	case IIO_CHAN_INFO_PROCESSED:
402 		ret = opt3001_get_lux(opt, val, val2);
403 		break;
404 	case IIO_CHAN_INFO_INT_TIME:
405 		ret = opt3001_get_int_time(opt, val, val2);
406 		break;
407 	default:
408 		ret = -EINVAL;
409 	}
410 
411 	mutex_unlock(&opt->lock);
412 
413 	return ret;
414 }
415 
416 static int opt3001_write_raw(struct iio_dev *iio,
417 		struct iio_chan_spec const *chan, int val, int val2,
418 		long mask)
419 {
420 	struct opt3001 *opt = iio_priv(iio);
421 	int ret;
422 
423 	if (opt->mode == OPT3001_CONFIGURATION_M_CONTINUOUS)
424 		return -EBUSY;
425 
426 	if (chan->type != IIO_LIGHT)
427 		return -EINVAL;
428 
429 	if (mask != IIO_CHAN_INFO_INT_TIME)
430 		return -EINVAL;
431 
432 	if (val != 0)
433 		return -EINVAL;
434 
435 	mutex_lock(&opt->lock);
436 	ret = opt3001_set_int_time(opt, val2);
437 	mutex_unlock(&opt->lock);
438 
439 	return ret;
440 }
441 
442 static int opt3001_read_event_value(struct iio_dev *iio,
443 		const struct iio_chan_spec *chan, enum iio_event_type type,
444 		enum iio_event_direction dir, enum iio_event_info info,
445 		int *val, int *val2)
446 {
447 	struct opt3001 *opt = iio_priv(iio);
448 	int ret = IIO_VAL_INT_PLUS_MICRO;
449 
450 	mutex_lock(&opt->lock);
451 
452 	switch (dir) {
453 	case IIO_EV_DIR_RISING:
454 		opt3001_to_iio_ret(opt, opt->high_thresh_exp,
455 				opt->high_thresh_mantissa, val, val2);
456 		break;
457 	case IIO_EV_DIR_FALLING:
458 		opt3001_to_iio_ret(opt, opt->low_thresh_exp,
459 				opt->low_thresh_mantissa, val, val2);
460 		break;
461 	default:
462 		ret = -EINVAL;
463 	}
464 
465 	mutex_unlock(&opt->lock);
466 
467 	return ret;
468 }
469 
470 static int opt3001_write_event_value(struct iio_dev *iio,
471 		const struct iio_chan_spec *chan, enum iio_event_type type,
472 		enum iio_event_direction dir, enum iio_event_info info,
473 		int val, int val2)
474 {
475 	struct opt3001 *opt = iio_priv(iio);
476 	int ret;
477 
478 	u16 mantissa;
479 	u16 value;
480 	u16 reg;
481 
482 	u8 exponent;
483 
484 	if (val < 0)
485 		return -EINVAL;
486 
487 	mutex_lock(&opt->lock);
488 
489 	ret = opt3001_find_scale(opt, val, val2, &exponent);
490 	if (ret < 0) {
491 		dev_err(opt->dev, "can't find scale for %d.%06u\n", val, val2);
492 		goto err;
493 	}
494 
495 	mantissa = (((val * 1000) + (val2 / 1000)) / 10) >> exponent;
496 	value = (exponent << 12) | mantissa;
497 
498 	switch (dir) {
499 	case IIO_EV_DIR_RISING:
500 		reg = OPT3001_HIGH_LIMIT;
501 		opt->high_thresh_mantissa = mantissa;
502 		opt->high_thresh_exp = exponent;
503 		break;
504 	case IIO_EV_DIR_FALLING:
505 		reg = OPT3001_LOW_LIMIT;
506 		opt->low_thresh_mantissa = mantissa;
507 		opt->low_thresh_exp = exponent;
508 		break;
509 	default:
510 		ret = -EINVAL;
511 		goto err;
512 	}
513 
514 	ret = i2c_smbus_write_word_swapped(opt->client, reg, value);
515 	if (ret < 0) {
516 		dev_err(opt->dev, "failed to write register %02x\n", reg);
517 		goto err;
518 	}
519 
520 err:
521 	mutex_unlock(&opt->lock);
522 
523 	return ret;
524 }
525 
526 static int opt3001_read_event_config(struct iio_dev *iio,
527 		const struct iio_chan_spec *chan, enum iio_event_type type,
528 		enum iio_event_direction dir)
529 {
530 	struct opt3001 *opt = iio_priv(iio);
531 
532 	return opt->mode == OPT3001_CONFIGURATION_M_CONTINUOUS;
533 }
534 
535 static int opt3001_write_event_config(struct iio_dev *iio,
536 		const struct iio_chan_spec *chan, enum iio_event_type type,
537 		enum iio_event_direction dir, int state)
538 {
539 	struct opt3001 *opt = iio_priv(iio);
540 	int ret;
541 	u16 mode;
542 	u16 reg;
543 
544 	if (state && opt->mode == OPT3001_CONFIGURATION_M_CONTINUOUS)
545 		return 0;
546 
547 	if (!state && opt->mode == OPT3001_CONFIGURATION_M_SHUTDOWN)
548 		return 0;
549 
550 	mutex_lock(&opt->lock);
551 
552 	mode = state ? OPT3001_CONFIGURATION_M_CONTINUOUS
553 		: OPT3001_CONFIGURATION_M_SHUTDOWN;
554 
555 	ret = i2c_smbus_read_word_swapped(opt->client, OPT3001_CONFIGURATION);
556 	if (ret < 0) {
557 		dev_err(opt->dev, "failed to read register %02x\n",
558 				OPT3001_CONFIGURATION);
559 		goto err;
560 	}
561 
562 	reg = ret;
563 	opt3001_set_mode(opt, &reg, mode);
564 
565 	ret = i2c_smbus_write_word_swapped(opt->client, OPT3001_CONFIGURATION,
566 			reg);
567 	if (ret < 0) {
568 		dev_err(opt->dev, "failed to write register %02x\n",
569 				OPT3001_CONFIGURATION);
570 		goto err;
571 	}
572 
573 err:
574 	mutex_unlock(&opt->lock);
575 
576 	return ret;
577 }
578 
579 static const struct iio_info opt3001_info = {
580 	.attrs = &opt3001_attribute_group,
581 	.read_raw = opt3001_read_raw,
582 	.write_raw = opt3001_write_raw,
583 	.read_event_value = opt3001_read_event_value,
584 	.write_event_value = opt3001_write_event_value,
585 	.read_event_config = opt3001_read_event_config,
586 	.write_event_config = opt3001_write_event_config,
587 };
588 
589 static int opt3001_read_id(struct opt3001 *opt)
590 {
591 	char manufacturer[2];
592 	u16 device_id;
593 	int ret;
594 
595 	ret = i2c_smbus_read_word_swapped(opt->client, OPT3001_MANUFACTURER_ID);
596 	if (ret < 0) {
597 		dev_err(opt->dev, "failed to read register %02x\n",
598 				OPT3001_MANUFACTURER_ID);
599 		return ret;
600 	}
601 
602 	manufacturer[0] = ret >> 8;
603 	manufacturer[1] = ret & 0xff;
604 
605 	ret = i2c_smbus_read_word_swapped(opt->client, OPT3001_DEVICE_ID);
606 	if (ret < 0) {
607 		dev_err(opt->dev, "failed to read register %02x\n",
608 				OPT3001_DEVICE_ID);
609 		return ret;
610 	}
611 
612 	device_id = ret;
613 
614 	dev_info(opt->dev, "Found %c%c OPT%04x\n", manufacturer[0],
615 			manufacturer[1], device_id);
616 
617 	return 0;
618 }
619 
620 static int opt3001_configure(struct opt3001 *opt)
621 {
622 	int ret;
623 	u16 reg;
624 
625 	ret = i2c_smbus_read_word_swapped(opt->client, OPT3001_CONFIGURATION);
626 	if (ret < 0) {
627 		dev_err(opt->dev, "failed to read register %02x\n",
628 				OPT3001_CONFIGURATION);
629 		return ret;
630 	}
631 
632 	reg = ret;
633 
634 	/* Enable automatic full-scale setting mode */
635 	reg &= ~OPT3001_CONFIGURATION_RN_MASK;
636 	reg |= OPT3001_CONFIGURATION_RN_AUTO;
637 
638 	/* Reflect status of the device's integration time setting */
639 	if (reg & OPT3001_CONFIGURATION_CT)
640 		opt->int_time = OPT3001_INT_TIME_LONG;
641 	else
642 		opt->int_time = OPT3001_INT_TIME_SHORT;
643 
644 	/* Ensure device is in shutdown initially */
645 	opt3001_set_mode(opt, &reg, OPT3001_CONFIGURATION_M_SHUTDOWN);
646 
647 	/* Configure for latched window-style comparison operation */
648 	reg |= OPT3001_CONFIGURATION_L;
649 	reg &= ~OPT3001_CONFIGURATION_POL;
650 	reg &= ~OPT3001_CONFIGURATION_ME;
651 	reg &= ~OPT3001_CONFIGURATION_FC_MASK;
652 
653 	ret = i2c_smbus_write_word_swapped(opt->client, OPT3001_CONFIGURATION,
654 			reg);
655 	if (ret < 0) {
656 		dev_err(opt->dev, "failed to write register %02x\n",
657 				OPT3001_CONFIGURATION);
658 		return ret;
659 	}
660 
661 	ret = i2c_smbus_read_word_swapped(opt->client, OPT3001_LOW_LIMIT);
662 	if (ret < 0) {
663 		dev_err(opt->dev, "failed to read register %02x\n",
664 				OPT3001_LOW_LIMIT);
665 		return ret;
666 	}
667 
668 	opt->low_thresh_mantissa = OPT3001_REG_MANTISSA(ret);
669 	opt->low_thresh_exp = OPT3001_REG_EXPONENT(ret);
670 
671 	ret = i2c_smbus_read_word_swapped(opt->client, OPT3001_HIGH_LIMIT);
672 	if (ret < 0) {
673 		dev_err(opt->dev, "failed to read register %02x\n",
674 				OPT3001_HIGH_LIMIT);
675 		return ret;
676 	}
677 
678 	opt->high_thresh_mantissa = OPT3001_REG_MANTISSA(ret);
679 	opt->high_thresh_exp = OPT3001_REG_EXPONENT(ret);
680 
681 	return 0;
682 }
683 
684 static irqreturn_t opt3001_irq(int irq, void *_iio)
685 {
686 	struct iio_dev *iio = _iio;
687 	struct opt3001 *opt = iio_priv(iio);
688 	int ret;
689 
690 	if (!opt->ok_to_ignore_lock)
691 		mutex_lock(&opt->lock);
692 
693 	ret = i2c_smbus_read_word_swapped(opt->client, OPT3001_CONFIGURATION);
694 	if (ret < 0) {
695 		dev_err(opt->dev, "failed to read register %02x\n",
696 				OPT3001_CONFIGURATION);
697 		goto out;
698 	}
699 
700 	if ((ret & OPT3001_CONFIGURATION_M_MASK) ==
701 			OPT3001_CONFIGURATION_M_CONTINUOUS) {
702 		if (ret & OPT3001_CONFIGURATION_FH)
703 			iio_push_event(iio,
704 					IIO_UNMOD_EVENT_CODE(IIO_LIGHT, 0,
705 							IIO_EV_TYPE_THRESH,
706 							IIO_EV_DIR_RISING),
707 					iio_get_time_ns(iio));
708 		if (ret & OPT3001_CONFIGURATION_FL)
709 			iio_push_event(iio,
710 					IIO_UNMOD_EVENT_CODE(IIO_LIGHT, 0,
711 							IIO_EV_TYPE_THRESH,
712 							IIO_EV_DIR_FALLING),
713 					iio_get_time_ns(iio));
714 	} else if (ret & OPT3001_CONFIGURATION_CRF) {
715 		ret = i2c_smbus_read_word_swapped(opt->client, OPT3001_RESULT);
716 		if (ret < 0) {
717 			dev_err(opt->dev, "failed to read register %02x\n",
718 					OPT3001_RESULT);
719 			goto out;
720 		}
721 		opt->result = ret;
722 		opt->result_ready = true;
723 		wake_up(&opt->result_ready_queue);
724 	}
725 
726 out:
727 	if (!opt->ok_to_ignore_lock)
728 		mutex_unlock(&opt->lock);
729 
730 	return IRQ_HANDLED;
731 }
732 
733 static int opt3001_probe(struct i2c_client *client,
734 		const struct i2c_device_id *id)
735 {
736 	struct device *dev = &client->dev;
737 
738 	struct iio_dev *iio;
739 	struct opt3001 *opt;
740 	int irq = client->irq;
741 	int ret;
742 
743 	iio = devm_iio_device_alloc(dev, sizeof(*opt));
744 	if (!iio)
745 		return -ENOMEM;
746 
747 	opt = iio_priv(iio);
748 	opt->client = client;
749 	opt->dev = dev;
750 
751 	mutex_init(&opt->lock);
752 	init_waitqueue_head(&opt->result_ready_queue);
753 	i2c_set_clientdata(client, iio);
754 
755 	ret = opt3001_read_id(opt);
756 	if (ret)
757 		return ret;
758 
759 	ret = opt3001_configure(opt);
760 	if (ret)
761 		return ret;
762 
763 	iio->name = client->name;
764 	iio->channels = opt3001_channels;
765 	iio->num_channels = ARRAY_SIZE(opt3001_channels);
766 	iio->dev.parent = dev;
767 	iio->modes = INDIO_DIRECT_MODE;
768 	iio->info = &opt3001_info;
769 
770 	ret = devm_iio_device_register(dev, iio);
771 	if (ret) {
772 		dev_err(dev, "failed to register IIO device\n");
773 		return ret;
774 	}
775 
776 	/* Make use of INT pin only if valid IRQ no. is given */
777 	if (irq > 0) {
778 		ret = request_threaded_irq(irq, NULL, opt3001_irq,
779 				IRQF_TRIGGER_FALLING | IRQF_ONESHOT,
780 				"opt3001", iio);
781 		if (ret) {
782 			dev_err(dev, "failed to request IRQ #%d\n", irq);
783 			return ret;
784 		}
785 		opt->use_irq = true;
786 	} else {
787 		dev_dbg(opt->dev, "enabling interrupt-less operation\n");
788 	}
789 
790 	return 0;
791 }
792 
793 static int opt3001_remove(struct i2c_client *client)
794 {
795 	struct iio_dev *iio = i2c_get_clientdata(client);
796 	struct opt3001 *opt = iio_priv(iio);
797 	int ret;
798 	u16 reg;
799 
800 	if (opt->use_irq)
801 		free_irq(client->irq, iio);
802 
803 	ret = i2c_smbus_read_word_swapped(opt->client, OPT3001_CONFIGURATION);
804 	if (ret < 0) {
805 		dev_err(opt->dev, "failed to read register %02x\n",
806 				OPT3001_CONFIGURATION);
807 		return ret;
808 	}
809 
810 	reg = ret;
811 	opt3001_set_mode(opt, &reg, OPT3001_CONFIGURATION_M_SHUTDOWN);
812 
813 	ret = i2c_smbus_write_word_swapped(opt->client, OPT3001_CONFIGURATION,
814 			reg);
815 	if (ret < 0) {
816 		dev_err(opt->dev, "failed to write register %02x\n",
817 				OPT3001_CONFIGURATION);
818 		return ret;
819 	}
820 
821 	return 0;
822 }
823 
824 static const struct i2c_device_id opt3001_id[] = {
825 	{ "opt3001", 0 },
826 	{ } /* Terminating Entry */
827 };
828 MODULE_DEVICE_TABLE(i2c, opt3001_id);
829 
830 static const struct of_device_id opt3001_of_match[] = {
831 	{ .compatible = "ti,opt3001" },
832 	{ }
833 };
834 MODULE_DEVICE_TABLE(of, opt3001_of_match);
835 
836 static struct i2c_driver opt3001_driver = {
837 	.probe = opt3001_probe,
838 	.remove = opt3001_remove,
839 	.id_table = opt3001_id,
840 
841 	.driver = {
842 		.name = "opt3001",
843 		.of_match_table = of_match_ptr(opt3001_of_match),
844 	},
845 };
846 
847 module_i2c_driver(opt3001_driver);
848 
849 MODULE_LICENSE("GPL v2");
850 MODULE_AUTHOR("Andreas Dannenberg <dannenberg@ti.com>");
851 MODULE_DESCRIPTION("Texas Instruments OPT3001 Light Sensor Driver");
852