xref: /openbmc/linux/drivers/iio/adc/max1363.c (revision f6723b56)
1  /*
2   * iio/adc/max1363.c
3   * Copyright (C) 2008-2010 Jonathan Cameron
4   *
5   * based on linux/drivers/i2c/chips/max123x
6   * Copyright (C) 2002-2004 Stefan Eletzhofer
7   *
8   * based on linux/drivers/acron/char/pcf8583.c
9   * Copyright (C) 2000 Russell King
10   *
11   * This program is free software; you can redistribute it and/or modify
12   * it under the terms of the GNU General Public License version 2 as
13   * published by the Free Software Foundation.
14   *
15   * max1363.c
16   *
17   * Partial support for max1363 and similar chips.
18   *
19   * Not currently implemented.
20   *
21   * - Control of internal reference.
22   */
23 
24 #include <linux/interrupt.h>
25 #include <linux/device.h>
26 #include <linux/kernel.h>
27 #include <linux/sysfs.h>
28 #include <linux/list.h>
29 #include <linux/i2c.h>
30 #include <linux/regulator/consumer.h>
31 #include <linux/slab.h>
32 #include <linux/err.h>
33 #include <linux/module.h>
34 
35 #include <linux/iio/iio.h>
36 #include <linux/iio/sysfs.h>
37 #include <linux/iio/events.h>
38 #include <linux/iio/buffer.h>
39 #include <linux/iio/driver.h>
40 #include <linux/iio/kfifo_buf.h>
41 #include <linux/iio/trigger_consumer.h>
42 #include <linux/iio/triggered_buffer.h>
43 
44 #define MAX1363_SETUP_BYTE(a) ((a) | 0x80)
45 
46 /* There is a fair bit more defined here than currently
47  * used, but the intention is to support everything these
48  * chips do in the long run */
49 
50 /* see data sheets */
51 /* max1363 and max1236, max1237, max1238, max1239 */
52 #define MAX1363_SETUP_AIN3_IS_AIN3_REF_IS_VDD	0x00
53 #define MAX1363_SETUP_AIN3_IS_REF_EXT_TO_REF	0x20
54 #define MAX1363_SETUP_AIN3_IS_AIN3_REF_IS_INT	0x40
55 #define MAX1363_SETUP_AIN3_IS_REF_REF_IS_INT	0x60
56 #define MAX1363_SETUP_POWER_UP_INT_REF		0x10
57 #define MAX1363_SETUP_POWER_DOWN_INT_REF	0x00
58 
59 /* think about including max11600 etc - more settings */
60 #define MAX1363_SETUP_EXT_CLOCK			0x08
61 #define MAX1363_SETUP_INT_CLOCK			0x00
62 #define MAX1363_SETUP_UNIPOLAR			0x00
63 #define MAX1363_SETUP_BIPOLAR			0x04
64 #define MAX1363_SETUP_RESET			0x00
65 #define MAX1363_SETUP_NORESET			0x02
66 /* max1363 only - though don't care on others.
67  * For now monitor modes are not implemented as the relevant
68  * line is not connected on my test board.
69  * The definitions are here as I intend to add this soon.
70  */
71 #define MAX1363_SETUP_MONITOR_SETUP		0x01
72 
73 /* Specific to the max1363 */
74 #define MAX1363_MON_RESET_CHAN(a) (1 << ((a) + 4))
75 #define MAX1363_MON_INT_ENABLE			0x01
76 
77 /* defined for readability reasons */
78 /* All chips */
79 #define MAX1363_CONFIG_BYTE(a) ((a))
80 
81 #define MAX1363_CONFIG_SE			0x01
82 #define MAX1363_CONFIG_DE			0x00
83 #define MAX1363_CONFIG_SCAN_TO_CS		0x00
84 #define MAX1363_CONFIG_SCAN_SINGLE_8		0x20
85 #define MAX1363_CONFIG_SCAN_MONITOR_MODE	0x40
86 #define MAX1363_CONFIG_SCAN_SINGLE_1		0x60
87 /* max123{6-9} only */
88 #define MAX1236_SCAN_MID_TO_CHANNEL		0x40
89 
90 /* max1363 only - merely part of channel selects or don't care for others */
91 #define MAX1363_CONFIG_EN_MON_MODE_READ 0x18
92 
93 #define MAX1363_CHANNEL_SEL(a) ((a) << 1)
94 
95 /* max1363 strictly 0x06 - but doesn't matter */
96 #define MAX1363_CHANNEL_SEL_MASK		0x1E
97 #define MAX1363_SCAN_MASK			0x60
98 #define MAX1363_SE_DE_MASK			0x01
99 
100 #define MAX1363_MAX_CHANNELS 25
101 /**
102  * struct max1363_mode - scan mode information
103  * @conf:	The corresponding value of the configuration register
104  * @modemask:	Bit mask corresponding to channels enabled in this mode
105  */
106 struct max1363_mode {
107 	int8_t		conf;
108 	DECLARE_BITMAP(modemask, MAX1363_MAX_CHANNELS);
109 };
110 
111 /* This must be maintained along side the max1363_mode_table in max1363_core */
112 enum max1363_modes {
113 	/* Single read of a single channel */
114 	_s0, _s1, _s2, _s3, _s4, _s5, _s6, _s7, _s8, _s9, _s10, _s11,
115 	/* Differential single read */
116 	d0m1, d2m3, d4m5, d6m7, d8m9, d10m11,
117 	d1m0, d3m2, d5m4, d7m6, d9m8, d11m10,
118 	/* Scan to channel and mid to channel where overlapping */
119 	s0to1, s0to2, s2to3, s0to3, s0to4, s0to5, s0to6,
120 	s6to7, s0to7, s6to8, s0to8, s6to9,
121 	s0to9, s6to10, s0to10, s6to11, s0to11,
122 	/* Differential scan to channel and mid to channel where overlapping */
123 	d0m1to2m3, d0m1to4m5, d0m1to6m7, d6m7to8m9,
124 	d0m1to8m9, d6m7to10m11, d0m1to10m11, d1m0to3m2,
125 	d1m0to5m4, d1m0to7m6, d7m6to9m8, d1m0to9m8,
126 	d7m6to11m10, d1m0to11m10,
127 };
128 
129 /**
130  * struct max1363_chip_info - chip specifc information
131  * @info:		iio core function callbacks structure
132  * @channels:		channel specification
133  * @num_channels:       number of channels
134  * @mode_list:		array of available scan modes
135  * @default_mode:	the scan mode in which the chip starts up
136  * @int_vref_mv:	the internal reference voltage
137  * @num_modes:		number of modes
138  * @bits:		accuracy of the adc in bits
139  */
140 struct max1363_chip_info {
141 	const struct iio_info		*info;
142 	const struct iio_chan_spec	*channels;
143 	int				num_channels;
144 	const enum max1363_modes	*mode_list;
145 	enum max1363_modes		default_mode;
146 	u16				int_vref_mv;
147 	u8				num_modes;
148 	u8				bits;
149 };
150 
151 /**
152  * struct max1363_state - driver instance specific data
153  * @client:		i2c_client
154  * @setupbyte:		cache of current device setup byte
155  * @configbyte:		cache of current device config byte
156  * @chip_info:		chip model specific constants, available modes, etc.
157  * @current_mode:	the scan mode of this chip
158  * @requestedmask:	a valid requested set of channels
159  * @reg:		supply regulator
160  * @monitor_on:		whether monitor mode is enabled
161  * @monitor_speed:	parameter corresponding to device monitor speed setting
162  * @mask_high:		bitmask for enabled high thresholds
163  * @mask_low:		bitmask for enabled low thresholds
164  * @thresh_high:	high threshold values
165  * @thresh_low:		low threshold values
166  * @vref:		Reference voltage regulator
167  * @vref_uv:		Actual (external or internal) reference voltage
168  * @send:		function used to send data to the chip
169  * @recv:		function used to receive data from the chip
170  */
171 struct max1363_state {
172 	struct i2c_client		*client;
173 	u8				setupbyte;
174 	u8				configbyte;
175 	const struct max1363_chip_info	*chip_info;
176 	const struct max1363_mode	*current_mode;
177 	u32				requestedmask;
178 	struct regulator		*reg;
179 
180 	/* Using monitor modes and buffer at the same time is
181 	   currently not supported */
182 	bool				monitor_on;
183 	unsigned int			monitor_speed:3;
184 	u8				mask_high;
185 	u8				mask_low;
186 	/* 4x unipolar first then the fours bipolar ones */
187 	s16				thresh_high[8];
188 	s16				thresh_low[8];
189 	struct regulator		*vref;
190 	u32				vref_uv;
191 	int				(*send)(const struct i2c_client *client,
192 						const char *buf, int count);
193 	int				(*recv)(const struct i2c_client *client,
194 						char *buf, int count);
195 };
196 
197 #define MAX1363_MODE_SINGLE(_num, _mask) {				\
198 		.conf = MAX1363_CHANNEL_SEL(_num)			\
199 			| MAX1363_CONFIG_SCAN_SINGLE_1			\
200 			| MAX1363_CONFIG_SE,				\
201 			.modemask[0] = _mask,				\
202 			}
203 
204 #define MAX1363_MODE_SCAN_TO_CHANNEL(_num, _mask) {			\
205 		.conf = MAX1363_CHANNEL_SEL(_num)			\
206 			| MAX1363_CONFIG_SCAN_TO_CS			\
207 			| MAX1363_CONFIG_SE,				\
208 			.modemask[0] = _mask,				\
209 			}
210 
211 /* note not available for max1363 hence naming */
212 #define MAX1236_MODE_SCAN_MID_TO_CHANNEL(_mid, _num, _mask) {		\
213 		.conf = MAX1363_CHANNEL_SEL(_num)			\
214 			| MAX1236_SCAN_MID_TO_CHANNEL			\
215 			| MAX1363_CONFIG_SE,				\
216 			.modemask[0] = _mask				\
217 }
218 
219 #define MAX1363_MODE_DIFF_SINGLE(_nump, _numm, _mask) {			\
220 		.conf = MAX1363_CHANNEL_SEL(_nump)			\
221 			| MAX1363_CONFIG_SCAN_SINGLE_1			\
222 			| MAX1363_CONFIG_DE,				\
223 			.modemask[0] = _mask				\
224 			}
225 
226 /* Can't think how to automate naming so specify for now */
227 #define MAX1363_MODE_DIFF_SCAN_TO_CHANNEL(_num, _numvals, _mask) {	\
228 		.conf = MAX1363_CHANNEL_SEL(_num)			\
229 			| MAX1363_CONFIG_SCAN_TO_CS			\
230 			| MAX1363_CONFIG_DE,				\
231 			.modemask[0] = _mask				\
232 			}
233 
234 /* note only available for max1363 hence naming */
235 #define MAX1236_MODE_DIFF_SCAN_MID_TO_CHANNEL(_num, _numvals, _mask) {	\
236 		.conf = MAX1363_CHANNEL_SEL(_num)			\
237 			| MAX1236_SCAN_MID_TO_CHANNEL			\
238 			| MAX1363_CONFIG_SE,				\
239 			.modemask[0] = _mask				\
240 }
241 
242 static const struct max1363_mode max1363_mode_table[] = {
243 	/* All of the single channel options first */
244 	MAX1363_MODE_SINGLE(0, 1 << 0),
245 	MAX1363_MODE_SINGLE(1, 1 << 1),
246 	MAX1363_MODE_SINGLE(2, 1 << 2),
247 	MAX1363_MODE_SINGLE(3, 1 << 3),
248 	MAX1363_MODE_SINGLE(4, 1 << 4),
249 	MAX1363_MODE_SINGLE(5, 1 << 5),
250 	MAX1363_MODE_SINGLE(6, 1 << 6),
251 	MAX1363_MODE_SINGLE(7, 1 << 7),
252 	MAX1363_MODE_SINGLE(8, 1 << 8),
253 	MAX1363_MODE_SINGLE(9, 1 << 9),
254 	MAX1363_MODE_SINGLE(10, 1 << 10),
255 	MAX1363_MODE_SINGLE(11, 1 << 11),
256 
257 	MAX1363_MODE_DIFF_SINGLE(0, 1, 1 << 12),
258 	MAX1363_MODE_DIFF_SINGLE(2, 3, 1 << 13),
259 	MAX1363_MODE_DIFF_SINGLE(4, 5, 1 << 14),
260 	MAX1363_MODE_DIFF_SINGLE(6, 7, 1 << 15),
261 	MAX1363_MODE_DIFF_SINGLE(8, 9, 1 << 16),
262 	MAX1363_MODE_DIFF_SINGLE(10, 11, 1 << 17),
263 	MAX1363_MODE_DIFF_SINGLE(1, 0, 1 << 18),
264 	MAX1363_MODE_DIFF_SINGLE(3, 2, 1 << 19),
265 	MAX1363_MODE_DIFF_SINGLE(5, 4, 1 << 20),
266 	MAX1363_MODE_DIFF_SINGLE(7, 6, 1 << 21),
267 	MAX1363_MODE_DIFF_SINGLE(9, 8, 1 << 22),
268 	MAX1363_MODE_DIFF_SINGLE(11, 10, 1 << 23),
269 
270 	/* The multichannel scans next */
271 	MAX1363_MODE_SCAN_TO_CHANNEL(1, 0x003),
272 	MAX1363_MODE_SCAN_TO_CHANNEL(2, 0x007),
273 	MAX1236_MODE_SCAN_MID_TO_CHANNEL(2, 3, 0x00C),
274 	MAX1363_MODE_SCAN_TO_CHANNEL(3, 0x00F),
275 	MAX1363_MODE_SCAN_TO_CHANNEL(4, 0x01F),
276 	MAX1363_MODE_SCAN_TO_CHANNEL(5, 0x03F),
277 	MAX1363_MODE_SCAN_TO_CHANNEL(6, 0x07F),
278 	MAX1236_MODE_SCAN_MID_TO_CHANNEL(6, 7, 0x0C0),
279 	MAX1363_MODE_SCAN_TO_CHANNEL(7, 0x0FF),
280 	MAX1236_MODE_SCAN_MID_TO_CHANNEL(6, 8, 0x1C0),
281 	MAX1363_MODE_SCAN_TO_CHANNEL(8, 0x1FF),
282 	MAX1236_MODE_SCAN_MID_TO_CHANNEL(6, 9, 0x3C0),
283 	MAX1363_MODE_SCAN_TO_CHANNEL(9, 0x3FF),
284 	MAX1236_MODE_SCAN_MID_TO_CHANNEL(6, 10, 0x7C0),
285 	MAX1363_MODE_SCAN_TO_CHANNEL(10, 0x7FF),
286 	MAX1236_MODE_SCAN_MID_TO_CHANNEL(6, 11, 0xFC0),
287 	MAX1363_MODE_SCAN_TO_CHANNEL(11, 0xFFF),
288 
289 	MAX1363_MODE_DIFF_SCAN_TO_CHANNEL(2, 2, 0x003000),
290 	MAX1363_MODE_DIFF_SCAN_TO_CHANNEL(4, 3, 0x007000),
291 	MAX1363_MODE_DIFF_SCAN_TO_CHANNEL(6, 4, 0x00F000),
292 	MAX1236_MODE_DIFF_SCAN_MID_TO_CHANNEL(8, 2, 0x018000),
293 	MAX1363_MODE_DIFF_SCAN_TO_CHANNEL(8, 5, 0x01F000),
294 	MAX1236_MODE_DIFF_SCAN_MID_TO_CHANNEL(10, 3, 0x038000),
295 	MAX1363_MODE_DIFF_SCAN_TO_CHANNEL(10, 6, 0x3F000),
296 	MAX1363_MODE_DIFF_SCAN_TO_CHANNEL(3, 2, 0x0C0000),
297 	MAX1363_MODE_DIFF_SCAN_TO_CHANNEL(5, 3, 0x1C0000),
298 	MAX1363_MODE_DIFF_SCAN_TO_CHANNEL(7, 4, 0x3C0000),
299 	MAX1236_MODE_DIFF_SCAN_MID_TO_CHANNEL(9, 2, 0x600000),
300 	MAX1363_MODE_DIFF_SCAN_TO_CHANNEL(9, 5, 0x7C0000),
301 	MAX1236_MODE_DIFF_SCAN_MID_TO_CHANNEL(11, 3, 0xE00000),
302 	MAX1363_MODE_DIFF_SCAN_TO_CHANNEL(11, 6, 0xFC0000),
303 };
304 
305 static const struct max1363_mode
306 *max1363_match_mode(const unsigned long *mask,
307 	const struct max1363_chip_info *ci)
308 {
309 	int i;
310 	if (mask)
311 		for (i = 0; i < ci->num_modes; i++)
312 			if (bitmap_subset(mask,
313 					  max1363_mode_table[ci->mode_list[i]].
314 					  modemask,
315 					  MAX1363_MAX_CHANNELS))
316 				return &max1363_mode_table[ci->mode_list[i]];
317 	return NULL;
318 }
319 
320 static int max1363_smbus_send(const struct i2c_client *client, const char *buf,
321 		int count)
322 {
323 	int i, err;
324 
325 	for (i = err = 0; err == 0 && i < count; ++i)
326 		err = i2c_smbus_write_byte(client, buf[i]);
327 
328 	return err ? err : count;
329 }
330 
331 static int max1363_smbus_recv(const struct i2c_client *client, char *buf,
332 		int count)
333 {
334 	int i, ret;
335 
336 	for (i = 0; i < count; ++i) {
337 		ret = i2c_smbus_read_byte(client);
338 		if (ret < 0)
339 			return ret;
340 		buf[i] = ret;
341 	}
342 
343 	return count;
344 }
345 
346 static int max1363_write_basic_config(struct max1363_state *st)
347 {
348 	u8 tx_buf[2] = { st->setupbyte, st->configbyte };
349 
350 	return st->send(st->client, tx_buf, 2);
351 }
352 
353 static int max1363_set_scan_mode(struct max1363_state *st)
354 {
355 	st->configbyte &= ~(MAX1363_CHANNEL_SEL_MASK
356 			    | MAX1363_SCAN_MASK
357 			    | MAX1363_SE_DE_MASK);
358 	st->configbyte |= st->current_mode->conf;
359 
360 	return max1363_write_basic_config(st);
361 }
362 
363 static int max1363_read_single_chan(struct iio_dev *indio_dev,
364 				    struct iio_chan_spec const *chan,
365 				    int *val,
366 				    long m)
367 {
368 	int ret = 0;
369 	s32 data;
370 	u8 rxbuf[2];
371 	struct max1363_state *st = iio_priv(indio_dev);
372 	struct i2c_client *client = st->client;
373 
374 	mutex_lock(&indio_dev->mlock);
375 	/*
376 	 * If monitor mode is enabled, the method for reading a single
377 	 * channel will have to be rather different and has not yet
378 	 * been implemented.
379 	 *
380 	 * Also, cannot read directly if buffered capture enabled.
381 	 */
382 	if (st->monitor_on || iio_buffer_enabled(indio_dev)) {
383 		ret = -EBUSY;
384 		goto error_ret;
385 	}
386 
387 	/* Check to see if current scan mode is correct */
388 	if (st->current_mode != &max1363_mode_table[chan->address]) {
389 		/* Update scan mode if needed */
390 		st->current_mode = &max1363_mode_table[chan->address];
391 		ret = max1363_set_scan_mode(st);
392 		if (ret < 0)
393 			goto error_ret;
394 	}
395 	if (st->chip_info->bits != 8) {
396 		/* Get reading */
397 		data = st->recv(client, rxbuf, 2);
398 		if (data < 0) {
399 			ret = data;
400 			goto error_ret;
401 		}
402 		data = (rxbuf[1] | rxbuf[0] << 8) &
403 		  ((1 << st->chip_info->bits) - 1);
404 	} else {
405 		/* Get reading */
406 		data = st->recv(client, rxbuf, 1);
407 		if (data < 0) {
408 			ret = data;
409 			goto error_ret;
410 		}
411 		data = rxbuf[0];
412 	}
413 	*val = data;
414 error_ret:
415 	mutex_unlock(&indio_dev->mlock);
416 	return ret;
417 
418 }
419 
420 static int max1363_read_raw(struct iio_dev *indio_dev,
421 			    struct iio_chan_spec const *chan,
422 			    int *val,
423 			    int *val2,
424 			    long m)
425 {
426 	struct max1363_state *st = iio_priv(indio_dev);
427 	int ret;
428 
429 	switch (m) {
430 	case IIO_CHAN_INFO_RAW:
431 		ret = max1363_read_single_chan(indio_dev, chan, val, m);
432 		if (ret < 0)
433 			return ret;
434 		return IIO_VAL_INT;
435 	case IIO_CHAN_INFO_SCALE:
436 		*val = st->vref_uv / 1000;
437 		*val2 = st->chip_info->bits;
438 		return IIO_VAL_FRACTIONAL_LOG2;
439 	default:
440 		return -EINVAL;
441 	}
442 	return 0;
443 }
444 
445 /* Applies to max1363 */
446 static const enum max1363_modes max1363_mode_list[] = {
447 	_s0, _s1, _s2, _s3,
448 	s0to1, s0to2, s0to3,
449 	d0m1, d2m3, d1m0, d3m2,
450 	d0m1to2m3, d1m0to3m2,
451 };
452 
453 static const struct iio_event_spec max1363_events[] = {
454 	{
455 		.type = IIO_EV_TYPE_THRESH,
456 		.dir = IIO_EV_DIR_RISING,
457 		.mask_separate = BIT(IIO_EV_INFO_VALUE) |
458 			BIT(IIO_EV_INFO_ENABLE),
459 	}, {
460 		.type = IIO_EV_TYPE_THRESH,
461 		.dir = IIO_EV_DIR_FALLING,
462 		.mask_separate = BIT(IIO_EV_INFO_VALUE) |
463 			BIT(IIO_EV_INFO_ENABLE),
464 	},
465 };
466 
467 #define MAX1363_CHAN_U(num, addr, si, bits, ev_spec, num_ev_spec)	\
468 	{								\
469 		.type = IIO_VOLTAGE,					\
470 		.indexed = 1,						\
471 		.channel = num,						\
472 		.address = addr,					\
473 		.info_mask_separate = BIT(IIO_CHAN_INFO_RAW),		\
474 		.info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE),	\
475 		.datasheet_name = "AIN"#num,				\
476 		.scan_type = {						\
477 			.sign = 'u',					\
478 			.realbits = bits,				\
479 			.storagebits = (bits > 8) ? 16 : 8,		\
480 			.endianness = IIO_BE,				\
481 		},							\
482 		.scan_index = si,					\
483 		.event_spec = ev_spec,					\
484 		.num_event_specs = num_ev_spec,				\
485 	}
486 
487 /* bipolar channel */
488 #define MAX1363_CHAN_B(num, num2, addr, si, bits, ev_spec, num_ev_spec)	\
489 	{								\
490 		.type = IIO_VOLTAGE,					\
491 		.differential = 1,					\
492 		.indexed = 1,						\
493 		.channel = num,						\
494 		.channel2 = num2,					\
495 		.address = addr,					\
496 		.info_mask_separate = BIT(IIO_CHAN_INFO_RAW),		\
497 		.info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE),	\
498 		.datasheet_name = "AIN"#num"-AIN"#num2,			\
499 		.scan_type = {						\
500 			.sign = 's',					\
501 			.realbits = bits,				\
502 			.storagebits = (bits > 8) ? 16 : 8,		\
503 			.endianness = IIO_BE,				\
504 		},							\
505 		.scan_index = si,					\
506 		.event_spec = ev_spec,					\
507 		.num_event_specs = num_ev_spec,				\
508 	}
509 
510 #define MAX1363_4X_CHANS(bits, ev_spec, num_ev_spec) {			\
511 	MAX1363_CHAN_U(0, _s0, 0, bits, ev_spec, num_ev_spec),		\
512 	MAX1363_CHAN_U(1, _s1, 1, bits, ev_spec, num_ev_spec),		\
513 	MAX1363_CHAN_U(2, _s2, 2, bits, ev_spec, num_ev_spec),		\
514 	MAX1363_CHAN_U(3, _s3, 3, bits, ev_spec, num_ev_spec),		\
515 	MAX1363_CHAN_B(0, 1, d0m1, 4, bits, ev_spec, num_ev_spec),	\
516 	MAX1363_CHAN_B(2, 3, d2m3, 5, bits, ev_spec, num_ev_spec),	\
517 	MAX1363_CHAN_B(1, 0, d1m0, 6, bits, ev_spec, num_ev_spec),	\
518 	MAX1363_CHAN_B(3, 2, d3m2, 7, bits, ev_spec, num_ev_spec),	\
519 	IIO_CHAN_SOFT_TIMESTAMP(8)					\
520 	}
521 
522 static const struct iio_chan_spec max1036_channels[] =
523 	MAX1363_4X_CHANS(8, NULL, 0);
524 static const struct iio_chan_spec max1136_channels[] =
525 	MAX1363_4X_CHANS(10, NULL, 0);
526 static const struct iio_chan_spec max1236_channels[] =
527 	MAX1363_4X_CHANS(12, NULL, 0);
528 static const struct iio_chan_spec max1361_channels[] =
529 	MAX1363_4X_CHANS(10, max1363_events, ARRAY_SIZE(max1363_events));
530 static const struct iio_chan_spec max1363_channels[] =
531 	MAX1363_4X_CHANS(12, max1363_events, ARRAY_SIZE(max1363_events));
532 
533 /* Applies to max1236, max1237 */
534 static const enum max1363_modes max1236_mode_list[] = {
535 	_s0, _s1, _s2, _s3,
536 	s0to1, s0to2, s0to3,
537 	d0m1, d2m3, d1m0, d3m2,
538 	d0m1to2m3, d1m0to3m2,
539 	s2to3,
540 };
541 
542 /* Applies to max1238, max1239 */
543 static const enum max1363_modes max1238_mode_list[] = {
544 	_s0, _s1, _s2, _s3, _s4, _s5, _s6, _s7, _s8, _s9, _s10, _s11,
545 	s0to1, s0to2, s0to3, s0to4, s0to5, s0to6,
546 	s0to7, s0to8, s0to9, s0to10, s0to11,
547 	d0m1, d2m3, d4m5, d6m7, d8m9, d10m11,
548 	d1m0, d3m2, d5m4, d7m6, d9m8, d11m10,
549 	d0m1to2m3, d0m1to4m5, d0m1to6m7, d0m1to8m9, d0m1to10m11,
550 	d1m0to3m2, d1m0to5m4, d1m0to7m6, d1m0to9m8, d1m0to11m10,
551 	s6to7, s6to8, s6to9, s6to10, s6to11,
552 	d6m7to8m9, d6m7to10m11, d7m6to9m8, d7m6to11m10,
553 };
554 
555 #define MAX1363_12X_CHANS(bits) {				\
556 	MAX1363_CHAN_U(0, _s0, 0, bits, NULL, 0),		\
557 	MAX1363_CHAN_U(1, _s1, 1, bits, NULL, 0),		\
558 	MAX1363_CHAN_U(2, _s2, 2, bits, NULL, 0),		\
559 	MAX1363_CHAN_U(3, _s3, 3, bits, NULL, 0),		\
560 	MAX1363_CHAN_U(4, _s4, 4, bits, NULL, 0),		\
561 	MAX1363_CHAN_U(5, _s5, 5, bits, NULL, 0),		\
562 	MAX1363_CHAN_U(6, _s6, 6, bits, NULL, 0),		\
563 	MAX1363_CHAN_U(7, _s7, 7, bits, NULL, 0),		\
564 	MAX1363_CHAN_U(8, _s8, 8, bits, NULL, 0),		\
565 	MAX1363_CHAN_U(9, _s9, 9, bits, NULL, 0),		\
566 	MAX1363_CHAN_U(10, _s10, 10, bits, NULL, 0),		\
567 	MAX1363_CHAN_U(11, _s11, 11, bits, NULL, 0),		\
568 	MAX1363_CHAN_B(0, 1, d0m1, 12, bits, NULL, 0),		\
569 	MAX1363_CHAN_B(2, 3, d2m3, 13, bits, NULL, 0),		\
570 	MAX1363_CHAN_B(4, 5, d4m5, 14, bits, NULL, 0),		\
571 	MAX1363_CHAN_B(6, 7, d6m7, 15, bits, NULL, 0),		\
572 	MAX1363_CHAN_B(8, 9, d8m9, 16, bits, NULL, 0),		\
573 	MAX1363_CHAN_B(10, 11, d10m11, 17, bits, NULL, 0),	\
574 	MAX1363_CHAN_B(1, 0, d1m0, 18, bits, NULL, 0),		\
575 	MAX1363_CHAN_B(3, 2, d3m2, 19, bits, NULL, 0),		\
576 	MAX1363_CHAN_B(5, 4, d5m4, 20, bits, NULL, 0),		\
577 	MAX1363_CHAN_B(7, 6, d7m6, 21, bits, NULL, 0),		\
578 	MAX1363_CHAN_B(9, 8, d9m8, 22, bits, NULL, 0),		\
579 	MAX1363_CHAN_B(11, 10, d11m10, 23, bits, NULL, 0),	\
580 	IIO_CHAN_SOFT_TIMESTAMP(24)				\
581 	}
582 static const struct iio_chan_spec max1038_channels[] = MAX1363_12X_CHANS(8);
583 static const struct iio_chan_spec max1138_channels[] = MAX1363_12X_CHANS(10);
584 static const struct iio_chan_spec max1238_channels[] = MAX1363_12X_CHANS(12);
585 
586 static const enum max1363_modes max11607_mode_list[] = {
587 	_s0, _s1, _s2, _s3,
588 	s0to1, s0to2, s0to3,
589 	s2to3,
590 	d0m1, d2m3, d1m0, d3m2,
591 	d0m1to2m3, d1m0to3m2,
592 };
593 
594 static const enum max1363_modes max11608_mode_list[] = {
595 	_s0, _s1, _s2, _s3, _s4, _s5, _s6, _s7,
596 	s0to1, s0to2, s0to3, s0to4, s0to5, s0to6, s0to7,
597 	s6to7,
598 	d0m1, d2m3, d4m5, d6m7,
599 	d1m0, d3m2, d5m4, d7m6,
600 	d0m1to2m3, d0m1to4m5, d0m1to6m7,
601 	d1m0to3m2, d1m0to5m4, d1m0to7m6,
602 };
603 
604 #define MAX1363_8X_CHANS(bits) {			\
605 	MAX1363_CHAN_U(0, _s0, 0, bits, NULL, 0),	\
606 	MAX1363_CHAN_U(1, _s1, 1, bits, NULL, 0),	\
607 	MAX1363_CHAN_U(2, _s2, 2, bits, NULL, 0),	\
608 	MAX1363_CHAN_U(3, _s3, 3, bits, NULL, 0),	\
609 	MAX1363_CHAN_U(4, _s4, 4, bits, NULL, 0),	\
610 	MAX1363_CHAN_U(5, _s5, 5, bits, NULL, 0),	\
611 	MAX1363_CHAN_U(6, _s6, 6, bits, NULL, 0),	\
612 	MAX1363_CHAN_U(7, _s7, 7, bits, NULL, 0),	\
613 	MAX1363_CHAN_B(0, 1, d0m1, 8, bits, NULL, 0),	\
614 	MAX1363_CHAN_B(2, 3, d2m3, 9, bits, NULL, 0),	\
615 	MAX1363_CHAN_B(4, 5, d4m5, 10, bits, NULL, 0),	\
616 	MAX1363_CHAN_B(6, 7, d6m7, 11, bits, NULL, 0),	\
617 	MAX1363_CHAN_B(1, 0, d1m0, 12, bits, NULL, 0),	\
618 	MAX1363_CHAN_B(3, 2, d3m2, 13, bits, NULL, 0),	\
619 	MAX1363_CHAN_B(5, 4, d5m4, 14, bits, NULL, 0),	\
620 	MAX1363_CHAN_B(7, 6, d7m6, 15, bits, NULL, 0),	\
621 	IIO_CHAN_SOFT_TIMESTAMP(16)			\
622 }
623 static const struct iio_chan_spec max11602_channels[] = MAX1363_8X_CHANS(8);
624 static const struct iio_chan_spec max11608_channels[] = MAX1363_8X_CHANS(10);
625 static const struct iio_chan_spec max11614_channels[] = MAX1363_8X_CHANS(12);
626 
627 static const enum max1363_modes max11644_mode_list[] = {
628 	_s0, _s1, s0to1, d0m1, d1m0,
629 };
630 
631 #define MAX1363_2X_CHANS(bits) {			\
632 	MAX1363_CHAN_U(0, _s0, 0, bits, NULL, 0),	\
633 	MAX1363_CHAN_U(1, _s1, 1, bits, NULL, 0),	\
634 	MAX1363_CHAN_B(0, 1, d0m1, 2, bits, NULL, 0),	\
635 	MAX1363_CHAN_B(1, 0, d1m0, 3, bits, NULL, 0),	\
636 	IIO_CHAN_SOFT_TIMESTAMP(4)			\
637 	}
638 
639 static const struct iio_chan_spec max11646_channels[] = MAX1363_2X_CHANS(10);
640 static const struct iio_chan_spec max11644_channels[] = MAX1363_2X_CHANS(12);
641 
642 enum { max1361,
643        max1362,
644        max1363,
645        max1364,
646        max1036,
647        max1037,
648        max1038,
649        max1039,
650        max1136,
651        max1137,
652        max1138,
653        max1139,
654        max1236,
655        max1237,
656        max1238,
657        max1239,
658        max11600,
659        max11601,
660        max11602,
661        max11603,
662        max11604,
663        max11605,
664        max11606,
665        max11607,
666        max11608,
667        max11609,
668        max11610,
669        max11611,
670        max11612,
671        max11613,
672        max11614,
673        max11615,
674        max11616,
675        max11617,
676        max11644,
677        max11645,
678        max11646,
679        max11647
680 };
681 
682 static const int max1363_monitor_speeds[] = { 133000, 665000, 33300, 16600,
683 					      8300, 4200, 2000, 1000 };
684 
685 static ssize_t max1363_monitor_show_freq(struct device *dev,
686 					struct device_attribute *attr,
687 					char *buf)
688 {
689 	struct max1363_state *st = iio_priv(dev_to_iio_dev(dev));
690 	return sprintf(buf, "%d\n", max1363_monitor_speeds[st->monitor_speed]);
691 }
692 
693 static ssize_t max1363_monitor_store_freq(struct device *dev,
694 					struct device_attribute *attr,
695 					const char *buf,
696 					size_t len)
697 {
698 	struct iio_dev *indio_dev = dev_to_iio_dev(dev);
699 	struct max1363_state *st = iio_priv(indio_dev);
700 	int i, ret;
701 	unsigned long val;
702 	bool found = false;
703 
704 	ret = kstrtoul(buf, 10, &val);
705 	if (ret)
706 		return -EINVAL;
707 	for (i = 0; i < ARRAY_SIZE(max1363_monitor_speeds); i++)
708 		if (val == max1363_monitor_speeds[i]) {
709 			found = true;
710 			break;
711 		}
712 	if (!found)
713 		return -EINVAL;
714 
715 	mutex_lock(&indio_dev->mlock);
716 	st->monitor_speed = i;
717 	mutex_unlock(&indio_dev->mlock);
718 
719 	return 0;
720 }
721 
722 static IIO_DEV_ATTR_SAMP_FREQ(S_IRUGO | S_IWUSR,
723 			max1363_monitor_show_freq,
724 			max1363_monitor_store_freq);
725 
726 static IIO_CONST_ATTR(sampling_frequency_available,
727 		"133000 665000 33300 16600 8300 4200 2000 1000");
728 
729 static int max1363_read_thresh(struct iio_dev *indio_dev,
730 	const struct iio_chan_spec *chan, enum iio_event_type type,
731 	enum iio_event_direction dir, enum iio_event_info info, int *val,
732 	int *val2)
733 {
734 	struct max1363_state *st = iio_priv(indio_dev);
735 	if (dir == IIO_EV_DIR_FALLING)
736 		*val = st->thresh_low[chan->channel];
737 	else
738 		*val = st->thresh_high[chan->channel];
739 	return IIO_VAL_INT;
740 }
741 
742 static int max1363_write_thresh(struct iio_dev *indio_dev,
743 	const struct iio_chan_spec *chan, enum iio_event_type type,
744 	enum iio_event_direction dir, enum iio_event_info info, int val,
745 	int val2)
746 {
747 	struct max1363_state *st = iio_priv(indio_dev);
748 	/* make it handle signed correctly as well */
749 	switch (st->chip_info->bits) {
750 	case 10:
751 		if (val > 0x3FF)
752 			return -EINVAL;
753 		break;
754 	case 12:
755 		if (val > 0xFFF)
756 			return -EINVAL;
757 		break;
758 	}
759 
760 	switch (dir) {
761 	case IIO_EV_DIR_FALLING:
762 		st->thresh_low[chan->channel] = val;
763 		break;
764 	case IIO_EV_DIR_RISING:
765 		st->thresh_high[chan->channel] = val;
766 		break;
767 	default:
768 		return -EINVAL;
769 	}
770 
771 	return 0;
772 }
773 
774 static const u64 max1363_event_codes[] = {
775 	IIO_UNMOD_EVENT_CODE(IIO_VOLTAGE, 0,
776 			     IIO_EV_TYPE_THRESH, IIO_EV_DIR_FALLING),
777 	IIO_UNMOD_EVENT_CODE(IIO_VOLTAGE, 1,
778 			     IIO_EV_TYPE_THRESH, IIO_EV_DIR_FALLING),
779 	IIO_UNMOD_EVENT_CODE(IIO_VOLTAGE, 2,
780 			     IIO_EV_TYPE_THRESH, IIO_EV_DIR_FALLING),
781 	IIO_UNMOD_EVENT_CODE(IIO_VOLTAGE, 3,
782 			     IIO_EV_TYPE_THRESH, IIO_EV_DIR_FALLING),
783 	IIO_UNMOD_EVENT_CODE(IIO_VOLTAGE, 0,
784 			     IIO_EV_TYPE_THRESH, IIO_EV_DIR_RISING),
785 	IIO_UNMOD_EVENT_CODE(IIO_VOLTAGE, 1,
786 			     IIO_EV_TYPE_THRESH, IIO_EV_DIR_RISING),
787 	IIO_UNMOD_EVENT_CODE(IIO_VOLTAGE, 2,
788 			     IIO_EV_TYPE_THRESH, IIO_EV_DIR_RISING),
789 	IIO_UNMOD_EVENT_CODE(IIO_VOLTAGE, 3,
790 			     IIO_EV_TYPE_THRESH, IIO_EV_DIR_RISING),
791 };
792 
793 static irqreturn_t max1363_event_handler(int irq, void *private)
794 {
795 	struct iio_dev *indio_dev = private;
796 	struct max1363_state *st = iio_priv(indio_dev);
797 	s64 timestamp = iio_get_time_ns();
798 	unsigned long mask, loc;
799 	u8 rx;
800 	u8 tx[2] = { st->setupbyte,
801 		     MAX1363_MON_INT_ENABLE | (st->monitor_speed << 1) | 0xF0 };
802 
803 	st->recv(st->client, &rx, 1);
804 	mask = rx;
805 	for_each_set_bit(loc, &mask, 8)
806 		iio_push_event(indio_dev, max1363_event_codes[loc], timestamp);
807 	st->send(st->client, tx, 2);
808 
809 	return IRQ_HANDLED;
810 }
811 
812 static int max1363_read_event_config(struct iio_dev *indio_dev,
813 	const struct iio_chan_spec *chan, enum iio_event_type type,
814 	enum iio_event_direction dir)
815 {
816 	struct max1363_state *st = iio_priv(indio_dev);
817 	int val;
818 	int number = chan->channel;
819 
820 	mutex_lock(&indio_dev->mlock);
821 	if (dir == IIO_EV_DIR_FALLING)
822 		val = (1 << number) & st->mask_low;
823 	else
824 		val = (1 << number) & st->mask_high;
825 	mutex_unlock(&indio_dev->mlock);
826 
827 	return val;
828 }
829 
830 static int max1363_monitor_mode_update(struct max1363_state *st, int enabled)
831 {
832 	u8 *tx_buf;
833 	int ret, i = 3, j;
834 	unsigned long numelements;
835 	int len;
836 	const long *modemask;
837 
838 	if (!enabled) {
839 		/* transition to buffered capture is not currently supported */
840 		st->setupbyte &= ~MAX1363_SETUP_MONITOR_SETUP;
841 		st->configbyte &= ~MAX1363_SCAN_MASK;
842 		st->monitor_on = false;
843 		return max1363_write_basic_config(st);
844 	}
845 
846 	/* Ensure we are in the relevant mode */
847 	st->setupbyte |= MAX1363_SETUP_MONITOR_SETUP;
848 	st->configbyte &= ~(MAX1363_CHANNEL_SEL_MASK
849 			    | MAX1363_SCAN_MASK
850 			| MAX1363_SE_DE_MASK);
851 	st->configbyte |= MAX1363_CONFIG_SCAN_MONITOR_MODE;
852 	if ((st->mask_low | st->mask_high) & 0x0F) {
853 		st->configbyte |= max1363_mode_table[s0to3].conf;
854 		modemask = max1363_mode_table[s0to3].modemask;
855 	} else if ((st->mask_low | st->mask_high) & 0x30) {
856 		st->configbyte |= max1363_mode_table[d0m1to2m3].conf;
857 		modemask = max1363_mode_table[d0m1to2m3].modemask;
858 	} else {
859 		st->configbyte |= max1363_mode_table[d1m0to3m2].conf;
860 		modemask = max1363_mode_table[d1m0to3m2].modemask;
861 	}
862 	numelements = bitmap_weight(modemask, MAX1363_MAX_CHANNELS);
863 	len = 3 * numelements + 3;
864 	tx_buf = kmalloc(len, GFP_KERNEL);
865 	if (!tx_buf) {
866 		ret = -ENOMEM;
867 		goto error_ret;
868 	}
869 	tx_buf[0] = st->configbyte;
870 	tx_buf[1] = st->setupbyte;
871 	tx_buf[2] = (st->monitor_speed << 1);
872 
873 	/*
874 	 * So we need to do yet another bit of nefarious scan mode
875 	 * setup to match what we need.
876 	 */
877 	for (j = 0; j < 8; j++)
878 		if (test_bit(j, modemask)) {
879 			/* Establish the mode is in the scan */
880 			if (st->mask_low & (1 << j)) {
881 				tx_buf[i] = (st->thresh_low[j] >> 4) & 0xFF;
882 				tx_buf[i + 1] = (st->thresh_low[j] << 4) & 0xF0;
883 			} else if (j < 4) {
884 				tx_buf[i] = 0;
885 				tx_buf[i + 1] = 0;
886 			} else {
887 				tx_buf[i] = 0x80;
888 				tx_buf[i + 1] = 0;
889 			}
890 			if (st->mask_high & (1 << j)) {
891 				tx_buf[i + 1] |=
892 					(st->thresh_high[j] >> 8) & 0x0F;
893 				tx_buf[i + 2] = st->thresh_high[j] & 0xFF;
894 			} else if (j < 4) {
895 				tx_buf[i + 1] |= 0x0F;
896 				tx_buf[i + 2] = 0xFF;
897 			} else {
898 				tx_buf[i + 1] |= 0x07;
899 				tx_buf[i + 2] = 0xFF;
900 			}
901 			i += 3;
902 		}
903 
904 
905 	ret = st->send(st->client, tx_buf, len);
906 	if (ret < 0)
907 		goto error_ret;
908 	if (ret != len) {
909 		ret = -EIO;
910 		goto error_ret;
911 	}
912 
913 	/*
914 	 * Now that we hopefully have sensible thresholds in place it is
915 	 * time to turn the interrupts on.
916 	 * It is unclear from the data sheet if this should be necessary
917 	 * (i.e. whether monitor mode setup is atomic) but it appears to
918 	 * be in practice.
919 	 */
920 	tx_buf[0] = st->setupbyte;
921 	tx_buf[1] = MAX1363_MON_INT_ENABLE | (st->monitor_speed << 1) | 0xF0;
922 	ret = st->send(st->client, tx_buf, 2);
923 	if (ret < 0)
924 		goto error_ret;
925 	if (ret != 2) {
926 		ret = -EIO;
927 		goto error_ret;
928 	}
929 	ret = 0;
930 	st->monitor_on = true;
931 error_ret:
932 
933 	kfree(tx_buf);
934 
935 	return ret;
936 }
937 
938 /*
939  * To keep this manageable we always use one of 3 scan modes.
940  * Scan 0...3, 0-1,2-3 and 1-0,3-2
941  */
942 
943 static inline int __max1363_check_event_mask(int thismask, int checkmask)
944 {
945 	int ret = 0;
946 	/* Is it unipolar */
947 	if (thismask < 4) {
948 		if (checkmask & ~0x0F) {
949 			ret = -EBUSY;
950 			goto error_ret;
951 		}
952 	} else if (thismask < 6) {
953 		if (checkmask & ~0x30) {
954 			ret = -EBUSY;
955 			goto error_ret;
956 		}
957 	} else if (checkmask & ~0xC0)
958 		ret = -EBUSY;
959 error_ret:
960 	return ret;
961 }
962 
963 static int max1363_write_event_config(struct iio_dev *indio_dev,
964 	const struct iio_chan_spec *chan, enum iio_event_type type,
965 	enum iio_event_direction dir, int state)
966 {
967 	int ret = 0;
968 	struct max1363_state *st = iio_priv(indio_dev);
969 	u16 unifiedmask;
970 	int number = chan->channel;
971 
972 	mutex_lock(&indio_dev->mlock);
973 	unifiedmask = st->mask_low | st->mask_high;
974 	if (dir == IIO_EV_DIR_FALLING) {
975 
976 		if (state == 0)
977 			st->mask_low &= ~(1 << number);
978 		else {
979 			ret = __max1363_check_event_mask((1 << number),
980 							 unifiedmask);
981 			if (ret)
982 				goto error_ret;
983 			st->mask_low |= (1 << number);
984 		}
985 	} else {
986 		if (state == 0)
987 			st->mask_high &= ~(1 << number);
988 		else {
989 			ret = __max1363_check_event_mask((1 << number),
990 							 unifiedmask);
991 			if (ret)
992 				goto error_ret;
993 			st->mask_high |= (1 << number);
994 		}
995 	}
996 
997 	max1363_monitor_mode_update(st, !!(st->mask_high | st->mask_low));
998 error_ret:
999 	mutex_unlock(&indio_dev->mlock);
1000 
1001 	return ret;
1002 }
1003 
1004 /*
1005  * As with scan_elements, only certain sets of these can
1006  * be combined.
1007  */
1008 static struct attribute *max1363_event_attributes[] = {
1009 	&iio_dev_attr_sampling_frequency.dev_attr.attr,
1010 	&iio_const_attr_sampling_frequency_available.dev_attr.attr,
1011 	NULL,
1012 };
1013 
1014 static struct attribute_group max1363_event_attribute_group = {
1015 	.attrs = max1363_event_attributes,
1016 	.name = "events",
1017 };
1018 
1019 static int max1363_update_scan_mode(struct iio_dev *indio_dev,
1020 				    const unsigned long *scan_mask)
1021 {
1022 	struct max1363_state *st = iio_priv(indio_dev);
1023 
1024 	/*
1025 	 * Need to figure out the current mode based upon the requested
1026 	 * scan mask in iio_dev
1027 	 */
1028 	st->current_mode = max1363_match_mode(scan_mask, st->chip_info);
1029 	if (!st->current_mode)
1030 		return -EINVAL;
1031 	max1363_set_scan_mode(st);
1032 	return 0;
1033 }
1034 
1035 static const struct iio_info max1238_info = {
1036 	.read_raw = &max1363_read_raw,
1037 	.driver_module = THIS_MODULE,
1038 	.update_scan_mode = &max1363_update_scan_mode,
1039 };
1040 
1041 static const struct iio_info max1363_info = {
1042 	.read_event_value = &max1363_read_thresh,
1043 	.write_event_value = &max1363_write_thresh,
1044 	.read_event_config = &max1363_read_event_config,
1045 	.write_event_config = &max1363_write_event_config,
1046 	.read_raw = &max1363_read_raw,
1047 	.update_scan_mode = &max1363_update_scan_mode,
1048 	.driver_module = THIS_MODULE,
1049 	.event_attrs = &max1363_event_attribute_group,
1050 };
1051 
1052 /* max1363 and max1368 tested - rest from data sheet */
1053 static const struct max1363_chip_info max1363_chip_info_tbl[] = {
1054 	[max1361] = {
1055 		.bits = 10,
1056 		.int_vref_mv = 2048,
1057 		.mode_list = max1363_mode_list,
1058 		.num_modes = ARRAY_SIZE(max1363_mode_list),
1059 		.default_mode = s0to3,
1060 		.channels = max1361_channels,
1061 		.num_channels = ARRAY_SIZE(max1361_channels),
1062 		.info = &max1363_info,
1063 	},
1064 	[max1362] = {
1065 		.bits = 10,
1066 		.int_vref_mv = 4096,
1067 		.mode_list = max1363_mode_list,
1068 		.num_modes = ARRAY_SIZE(max1363_mode_list),
1069 		.default_mode = s0to3,
1070 		.channels = max1361_channels,
1071 		.num_channels = ARRAY_SIZE(max1361_channels),
1072 		.info = &max1363_info,
1073 	},
1074 	[max1363] = {
1075 		.bits = 12,
1076 		.int_vref_mv = 2048,
1077 		.mode_list = max1363_mode_list,
1078 		.num_modes = ARRAY_SIZE(max1363_mode_list),
1079 		.default_mode = s0to3,
1080 		.channels = max1363_channels,
1081 		.num_channels = ARRAY_SIZE(max1363_channels),
1082 		.info = &max1363_info,
1083 	},
1084 	[max1364] = {
1085 		.bits = 12,
1086 		.int_vref_mv = 4096,
1087 		.mode_list = max1363_mode_list,
1088 		.num_modes = ARRAY_SIZE(max1363_mode_list),
1089 		.default_mode = s0to3,
1090 		.channels = max1363_channels,
1091 		.num_channels = ARRAY_SIZE(max1363_channels),
1092 		.info = &max1363_info,
1093 	},
1094 	[max1036] = {
1095 		.bits = 8,
1096 		.int_vref_mv = 4096,
1097 		.mode_list = max1236_mode_list,
1098 		.num_modes = ARRAY_SIZE(max1236_mode_list),
1099 		.default_mode = s0to3,
1100 		.info = &max1238_info,
1101 		.channels = max1036_channels,
1102 		.num_channels = ARRAY_SIZE(max1036_channels),
1103 	},
1104 	[max1037] = {
1105 		.bits = 8,
1106 		.int_vref_mv = 2048,
1107 		.mode_list = max1236_mode_list,
1108 		.num_modes = ARRAY_SIZE(max1236_mode_list),
1109 		.default_mode = s0to3,
1110 		.info = &max1238_info,
1111 		.channels = max1036_channels,
1112 		.num_channels = ARRAY_SIZE(max1036_channels),
1113 	},
1114 	[max1038] = {
1115 		.bits = 8,
1116 		.int_vref_mv = 4096,
1117 		.mode_list = max1238_mode_list,
1118 		.num_modes = ARRAY_SIZE(max1238_mode_list),
1119 		.default_mode = s0to11,
1120 		.info = &max1238_info,
1121 		.channels = max1038_channels,
1122 		.num_channels = ARRAY_SIZE(max1038_channels),
1123 	},
1124 	[max1039] = {
1125 		.bits = 8,
1126 		.int_vref_mv = 2048,
1127 		.mode_list = max1238_mode_list,
1128 		.num_modes = ARRAY_SIZE(max1238_mode_list),
1129 		.default_mode = s0to11,
1130 		.info = &max1238_info,
1131 		.channels = max1038_channels,
1132 		.num_channels = ARRAY_SIZE(max1038_channels),
1133 	},
1134 	[max1136] = {
1135 		.bits = 10,
1136 		.int_vref_mv = 4096,
1137 		.mode_list = max1236_mode_list,
1138 		.num_modes = ARRAY_SIZE(max1236_mode_list),
1139 		.default_mode = s0to3,
1140 		.info = &max1238_info,
1141 		.channels = max1136_channels,
1142 		.num_channels = ARRAY_SIZE(max1136_channels),
1143 	},
1144 	[max1137] = {
1145 		.bits = 10,
1146 		.int_vref_mv = 2048,
1147 		.mode_list = max1236_mode_list,
1148 		.num_modes = ARRAY_SIZE(max1236_mode_list),
1149 		.default_mode = s0to3,
1150 		.info = &max1238_info,
1151 		.channels = max1136_channels,
1152 		.num_channels = ARRAY_SIZE(max1136_channels),
1153 	},
1154 	[max1138] = {
1155 		.bits = 10,
1156 		.int_vref_mv = 4096,
1157 		.mode_list = max1238_mode_list,
1158 		.num_modes = ARRAY_SIZE(max1238_mode_list),
1159 		.default_mode = s0to11,
1160 		.info = &max1238_info,
1161 		.channels = max1138_channels,
1162 		.num_channels = ARRAY_SIZE(max1138_channels),
1163 	},
1164 	[max1139] = {
1165 		.bits = 10,
1166 		.int_vref_mv = 2048,
1167 		.mode_list = max1238_mode_list,
1168 		.num_modes = ARRAY_SIZE(max1238_mode_list),
1169 		.default_mode = s0to11,
1170 		.info = &max1238_info,
1171 		.channels = max1138_channels,
1172 		.num_channels = ARRAY_SIZE(max1138_channels),
1173 	},
1174 	[max1236] = {
1175 		.bits = 12,
1176 		.int_vref_mv = 4096,
1177 		.mode_list = max1236_mode_list,
1178 		.num_modes = ARRAY_SIZE(max1236_mode_list),
1179 		.default_mode = s0to3,
1180 		.info = &max1238_info,
1181 		.channels = max1236_channels,
1182 		.num_channels = ARRAY_SIZE(max1236_channels),
1183 	},
1184 	[max1237] = {
1185 		.bits = 12,
1186 		.int_vref_mv = 2048,
1187 		.mode_list = max1236_mode_list,
1188 		.num_modes = ARRAY_SIZE(max1236_mode_list),
1189 		.default_mode = s0to3,
1190 		.info = &max1238_info,
1191 		.channels = max1236_channels,
1192 		.num_channels = ARRAY_SIZE(max1236_channels),
1193 	},
1194 	[max1238] = {
1195 		.bits = 12,
1196 		.int_vref_mv = 4096,
1197 		.mode_list = max1238_mode_list,
1198 		.num_modes = ARRAY_SIZE(max1238_mode_list),
1199 		.default_mode = s0to11,
1200 		.info = &max1238_info,
1201 		.channels = max1238_channels,
1202 		.num_channels = ARRAY_SIZE(max1238_channels),
1203 	},
1204 	[max1239] = {
1205 		.bits = 12,
1206 		.int_vref_mv = 2048,
1207 		.mode_list = max1238_mode_list,
1208 		.num_modes = ARRAY_SIZE(max1238_mode_list),
1209 		.default_mode = s0to11,
1210 		.info = &max1238_info,
1211 		.channels = max1238_channels,
1212 		.num_channels = ARRAY_SIZE(max1238_channels),
1213 	},
1214 	[max11600] = {
1215 		.bits = 8,
1216 		.int_vref_mv = 4096,
1217 		.mode_list = max11607_mode_list,
1218 		.num_modes = ARRAY_SIZE(max11607_mode_list),
1219 		.default_mode = s0to3,
1220 		.info = &max1238_info,
1221 		.channels = max1036_channels,
1222 		.num_channels = ARRAY_SIZE(max1036_channels),
1223 	},
1224 	[max11601] = {
1225 		.bits = 8,
1226 		.int_vref_mv = 2048,
1227 		.mode_list = max11607_mode_list,
1228 		.num_modes = ARRAY_SIZE(max11607_mode_list),
1229 		.default_mode = s0to3,
1230 		.info = &max1238_info,
1231 		.channels = max1036_channels,
1232 		.num_channels = ARRAY_SIZE(max1036_channels),
1233 	},
1234 	[max11602] = {
1235 		.bits = 8,
1236 		.int_vref_mv = 4096,
1237 		.mode_list = max11608_mode_list,
1238 		.num_modes = ARRAY_SIZE(max11608_mode_list),
1239 		.default_mode = s0to7,
1240 		.info = &max1238_info,
1241 		.channels = max11602_channels,
1242 		.num_channels = ARRAY_SIZE(max11602_channels),
1243 	},
1244 	[max11603] = {
1245 		.bits = 8,
1246 		.int_vref_mv = 2048,
1247 		.mode_list = max11608_mode_list,
1248 		.num_modes = ARRAY_SIZE(max11608_mode_list),
1249 		.default_mode = s0to7,
1250 		.info = &max1238_info,
1251 		.channels = max11602_channels,
1252 		.num_channels = ARRAY_SIZE(max11602_channels),
1253 	},
1254 	[max11604] = {
1255 		.bits = 8,
1256 		.int_vref_mv = 4098,
1257 		.mode_list = max1238_mode_list,
1258 		.num_modes = ARRAY_SIZE(max1238_mode_list),
1259 		.default_mode = s0to11,
1260 		.info = &max1238_info,
1261 		.channels = max1238_channels,
1262 		.num_channels = ARRAY_SIZE(max1238_channels),
1263 	},
1264 	[max11605] = {
1265 		.bits = 8,
1266 		.int_vref_mv = 2048,
1267 		.mode_list = max1238_mode_list,
1268 		.num_modes = ARRAY_SIZE(max1238_mode_list),
1269 		.default_mode = s0to11,
1270 		.info = &max1238_info,
1271 		.channels = max1238_channels,
1272 		.num_channels = ARRAY_SIZE(max1238_channels),
1273 	},
1274 	[max11606] = {
1275 		.bits = 10,
1276 		.int_vref_mv = 4096,
1277 		.mode_list = max11607_mode_list,
1278 		.num_modes = ARRAY_SIZE(max11607_mode_list),
1279 		.default_mode = s0to3,
1280 		.info = &max1238_info,
1281 		.channels = max1136_channels,
1282 		.num_channels = ARRAY_SIZE(max1136_channels),
1283 	},
1284 	[max11607] = {
1285 		.bits = 10,
1286 		.int_vref_mv = 2048,
1287 		.mode_list = max11607_mode_list,
1288 		.num_modes = ARRAY_SIZE(max11607_mode_list),
1289 		.default_mode = s0to3,
1290 		.info = &max1238_info,
1291 		.channels = max1136_channels,
1292 		.num_channels = ARRAY_SIZE(max1136_channels),
1293 	},
1294 	[max11608] = {
1295 		.bits = 10,
1296 		.int_vref_mv = 4096,
1297 		.mode_list = max11608_mode_list,
1298 		.num_modes = ARRAY_SIZE(max11608_mode_list),
1299 		.default_mode = s0to7,
1300 		.info = &max1238_info,
1301 		.channels = max11608_channels,
1302 		.num_channels = ARRAY_SIZE(max11608_channels),
1303 	},
1304 	[max11609] = {
1305 		.bits = 10,
1306 		.int_vref_mv = 2048,
1307 		.mode_list = max11608_mode_list,
1308 		.num_modes = ARRAY_SIZE(max11608_mode_list),
1309 		.default_mode = s0to7,
1310 		.info = &max1238_info,
1311 		.channels = max11608_channels,
1312 		.num_channels = ARRAY_SIZE(max11608_channels),
1313 	},
1314 	[max11610] = {
1315 		.bits = 10,
1316 		.int_vref_mv = 4098,
1317 		.mode_list = max1238_mode_list,
1318 		.num_modes = ARRAY_SIZE(max1238_mode_list),
1319 		.default_mode = s0to11,
1320 		.info = &max1238_info,
1321 		.channels = max1238_channels,
1322 		.num_channels = ARRAY_SIZE(max1238_channels),
1323 	},
1324 	[max11611] = {
1325 		.bits = 10,
1326 		.int_vref_mv = 2048,
1327 		.mode_list = max1238_mode_list,
1328 		.num_modes = ARRAY_SIZE(max1238_mode_list),
1329 		.default_mode = s0to11,
1330 		.info = &max1238_info,
1331 		.channels = max1238_channels,
1332 		.num_channels = ARRAY_SIZE(max1238_channels),
1333 	},
1334 	[max11612] = {
1335 		.bits = 12,
1336 		.int_vref_mv = 4096,
1337 		.mode_list = max11607_mode_list,
1338 		.num_modes = ARRAY_SIZE(max11607_mode_list),
1339 		.default_mode = s0to3,
1340 		.info = &max1238_info,
1341 		.channels = max1363_channels,
1342 		.num_channels = ARRAY_SIZE(max1363_channels),
1343 	},
1344 	[max11613] = {
1345 		.bits = 12,
1346 		.int_vref_mv = 2048,
1347 		.mode_list = max11607_mode_list,
1348 		.num_modes = ARRAY_SIZE(max11607_mode_list),
1349 		.default_mode = s0to3,
1350 		.info = &max1238_info,
1351 		.channels = max1363_channels,
1352 		.num_channels = ARRAY_SIZE(max1363_channels),
1353 	},
1354 	[max11614] = {
1355 		.bits = 12,
1356 		.int_vref_mv = 4096,
1357 		.mode_list = max11608_mode_list,
1358 		.num_modes = ARRAY_SIZE(max11608_mode_list),
1359 		.default_mode = s0to7,
1360 		.info = &max1238_info,
1361 		.channels = max11614_channels,
1362 		.num_channels = ARRAY_SIZE(max11614_channels),
1363 	},
1364 	[max11615] = {
1365 		.bits = 12,
1366 		.int_vref_mv = 2048,
1367 		.mode_list = max11608_mode_list,
1368 		.num_modes = ARRAY_SIZE(max11608_mode_list),
1369 		.default_mode = s0to7,
1370 		.info = &max1238_info,
1371 		.channels = max11614_channels,
1372 		.num_channels = ARRAY_SIZE(max11614_channels),
1373 	},
1374 	[max11616] = {
1375 		.bits = 12,
1376 		.int_vref_mv = 4098,
1377 		.mode_list = max1238_mode_list,
1378 		.num_modes = ARRAY_SIZE(max1238_mode_list),
1379 		.default_mode = s0to11,
1380 		.info = &max1238_info,
1381 		.channels = max1238_channels,
1382 		.num_channels = ARRAY_SIZE(max1238_channels),
1383 	},
1384 	[max11617] = {
1385 		.bits = 12,
1386 		.int_vref_mv = 2048,
1387 		.mode_list = max1238_mode_list,
1388 		.num_modes = ARRAY_SIZE(max1238_mode_list),
1389 		.default_mode = s0to11,
1390 		.info = &max1238_info,
1391 		.channels = max1238_channels,
1392 		.num_channels = ARRAY_SIZE(max1238_channels),
1393 	},
1394 	[max11644] = {
1395 		.bits = 12,
1396 		.int_vref_mv = 2048,
1397 		.mode_list = max11644_mode_list,
1398 		.num_modes = ARRAY_SIZE(max11644_mode_list),
1399 		.default_mode = s0to1,
1400 		.info = &max1238_info,
1401 		.channels = max11644_channels,
1402 		.num_channels = ARRAY_SIZE(max11644_channels),
1403 	},
1404 	[max11645] = {
1405 		.bits = 12,
1406 		.int_vref_mv = 4096,
1407 		.mode_list = max11644_mode_list,
1408 		.num_modes = ARRAY_SIZE(max11644_mode_list),
1409 		.default_mode = s0to1,
1410 		.info = &max1238_info,
1411 		.channels = max11644_channels,
1412 		.num_channels = ARRAY_SIZE(max11644_channels),
1413 	},
1414 	[max11646] = {
1415 		.bits = 10,
1416 		.int_vref_mv = 2048,
1417 		.mode_list = max11644_mode_list,
1418 		.num_modes = ARRAY_SIZE(max11644_mode_list),
1419 		.default_mode = s0to1,
1420 		.info = &max1238_info,
1421 		.channels = max11646_channels,
1422 		.num_channels = ARRAY_SIZE(max11646_channels),
1423 	},
1424 	[max11647] = {
1425 		.bits = 10,
1426 		.int_vref_mv = 4096,
1427 		.mode_list = max11644_mode_list,
1428 		.num_modes = ARRAY_SIZE(max11644_mode_list),
1429 		.default_mode = s0to1,
1430 		.info = &max1238_info,
1431 		.channels = max11646_channels,
1432 		.num_channels = ARRAY_SIZE(max11646_channels),
1433 	},
1434 };
1435 
1436 static int max1363_initial_setup(struct max1363_state *st)
1437 {
1438 	st->setupbyte = MAX1363_SETUP_INT_CLOCK
1439 		| MAX1363_SETUP_UNIPOLAR
1440 		| MAX1363_SETUP_NORESET;
1441 
1442 	if (st->vref)
1443 		st->setupbyte |= MAX1363_SETUP_AIN3_IS_REF_EXT_TO_REF;
1444 	else
1445 		st->setupbyte |= MAX1363_SETUP_POWER_UP_INT_REF
1446 		  | MAX1363_SETUP_AIN3_IS_AIN3_REF_IS_INT;
1447 
1448 	/* Set scan mode writes the config anyway so wait until then */
1449 	st->setupbyte = MAX1363_SETUP_BYTE(st->setupbyte);
1450 	st->current_mode = &max1363_mode_table[st->chip_info->default_mode];
1451 	st->configbyte = MAX1363_CONFIG_BYTE(st->configbyte);
1452 
1453 	return max1363_set_scan_mode(st);
1454 }
1455 
1456 static int max1363_alloc_scan_masks(struct iio_dev *indio_dev)
1457 {
1458 	struct max1363_state *st = iio_priv(indio_dev);
1459 	unsigned long *masks;
1460 	int i;
1461 
1462 	masks = devm_kzalloc(&indio_dev->dev,
1463 			BITS_TO_LONGS(MAX1363_MAX_CHANNELS) * sizeof(long) *
1464 			(st->chip_info->num_modes + 1), GFP_KERNEL);
1465 	if (!masks)
1466 		return -ENOMEM;
1467 
1468 	for (i = 0; i < st->chip_info->num_modes; i++)
1469 		bitmap_copy(masks + BITS_TO_LONGS(MAX1363_MAX_CHANNELS)*i,
1470 			    max1363_mode_table[st->chip_info->mode_list[i]]
1471 			    .modemask, MAX1363_MAX_CHANNELS);
1472 
1473 	indio_dev->available_scan_masks = masks;
1474 
1475 	return 0;
1476 }
1477 
1478 static irqreturn_t max1363_trigger_handler(int irq, void *p)
1479 {
1480 	struct iio_poll_func *pf = p;
1481 	struct iio_dev *indio_dev = pf->indio_dev;
1482 	struct max1363_state *st = iio_priv(indio_dev);
1483 	__u8 *rxbuf;
1484 	int b_sent;
1485 	size_t d_size;
1486 	unsigned long numvals = bitmap_weight(st->current_mode->modemask,
1487 					      MAX1363_MAX_CHANNELS);
1488 
1489 	/* Ensure the timestamp is 8 byte aligned */
1490 	if (st->chip_info->bits != 8)
1491 		d_size = numvals*2;
1492 	else
1493 		d_size = numvals;
1494 	if (indio_dev->scan_timestamp) {
1495 		d_size += sizeof(s64);
1496 		if (d_size % sizeof(s64))
1497 			d_size += sizeof(s64) - (d_size % sizeof(s64));
1498 	}
1499 	/* Monitor mode prevents reading. Whilst not currently implemented
1500 	 * might as well have this test in here in the meantime as it does
1501 	 * no harm.
1502 	 */
1503 	if (numvals == 0)
1504 		goto done;
1505 
1506 	rxbuf = kmalloc(d_size,	GFP_KERNEL);
1507 	if (rxbuf == NULL)
1508 		goto done;
1509 	if (st->chip_info->bits != 8)
1510 		b_sent = st->recv(st->client, rxbuf, numvals * 2);
1511 	else
1512 		b_sent = st->recv(st->client, rxbuf, numvals);
1513 	if (b_sent < 0)
1514 		goto done_free;
1515 
1516 	iio_push_to_buffers_with_timestamp(indio_dev, rxbuf, iio_get_time_ns());
1517 
1518 done_free:
1519 	kfree(rxbuf);
1520 done:
1521 	iio_trigger_notify_done(indio_dev->trig);
1522 
1523 	return IRQ_HANDLED;
1524 }
1525 
1526 static int max1363_probe(struct i2c_client *client,
1527 			 const struct i2c_device_id *id)
1528 {
1529 	int ret;
1530 	struct max1363_state *st;
1531 	struct iio_dev *indio_dev;
1532 	struct regulator *vref;
1533 
1534 	indio_dev = devm_iio_device_alloc(&client->dev,
1535 					  sizeof(struct max1363_state));
1536 	if (!indio_dev)
1537 		return -ENOMEM;
1538 
1539 	indio_dev->dev.of_node = client->dev.of_node;
1540 	ret = iio_map_array_register(indio_dev, client->dev.platform_data);
1541 	if (ret < 0)
1542 		return ret;
1543 
1544 	st = iio_priv(indio_dev);
1545 
1546 	st->reg = devm_regulator_get(&client->dev, "vcc");
1547 	if (IS_ERR(st->reg)) {
1548 		ret = PTR_ERR(st->reg);
1549 		goto error_unregister_map;
1550 	}
1551 
1552 	ret = regulator_enable(st->reg);
1553 	if (ret)
1554 		goto error_unregister_map;
1555 
1556 	/* this is only used for device removal purposes */
1557 	i2c_set_clientdata(client, indio_dev);
1558 
1559 	st->chip_info = &max1363_chip_info_tbl[id->driver_data];
1560 	st->client = client;
1561 
1562 	st->vref_uv = st->chip_info->int_vref_mv * 1000;
1563 	vref = devm_regulator_get_optional(&client->dev, "vref");
1564 	if (!IS_ERR(vref)) {
1565 		int vref_uv;
1566 
1567 		ret = regulator_enable(vref);
1568 		if (ret)
1569 			goto error_disable_reg;
1570 		st->vref = vref;
1571 		vref_uv = regulator_get_voltage(vref);
1572 		if (vref_uv <= 0) {
1573 			ret = -EINVAL;
1574 			goto error_disable_reg;
1575 		}
1576 		st->vref_uv = vref_uv;
1577 	}
1578 
1579 	if (i2c_check_functionality(client->adapter, I2C_FUNC_I2C)) {
1580 		st->send = i2c_master_send;
1581 		st->recv = i2c_master_recv;
1582 	} else if (i2c_check_functionality(client->adapter, I2C_FUNC_SMBUS_BYTE)
1583 			&& st->chip_info->bits == 8) {
1584 		st->send = max1363_smbus_send;
1585 		st->recv = max1363_smbus_recv;
1586 	} else {
1587 		ret = -EOPNOTSUPP;
1588 		goto error_disable_reg;
1589 	}
1590 
1591 	ret = max1363_alloc_scan_masks(indio_dev);
1592 	if (ret)
1593 		goto error_disable_reg;
1594 
1595 	/* Establish that the iio_dev is a child of the i2c device */
1596 	indio_dev->dev.parent = &client->dev;
1597 	indio_dev->name = id->name;
1598 	indio_dev->channels = st->chip_info->channels;
1599 	indio_dev->num_channels = st->chip_info->num_channels;
1600 	indio_dev->info = st->chip_info->info;
1601 	indio_dev->modes = INDIO_DIRECT_MODE;
1602 	ret = max1363_initial_setup(st);
1603 	if (ret < 0)
1604 		goto error_disable_reg;
1605 
1606 	ret = iio_triggered_buffer_setup(indio_dev, NULL,
1607 		&max1363_trigger_handler, NULL);
1608 	if (ret)
1609 		goto error_disable_reg;
1610 
1611 	if (client->irq) {
1612 		ret = devm_request_threaded_irq(&client->dev, st->client->irq,
1613 					   NULL,
1614 					   &max1363_event_handler,
1615 					   IRQF_TRIGGER_RISING | IRQF_ONESHOT,
1616 					   "max1363_event",
1617 					   indio_dev);
1618 
1619 		if (ret)
1620 			goto error_uninit_buffer;
1621 	}
1622 
1623 	ret = iio_device_register(indio_dev);
1624 	if (ret < 0)
1625 		goto error_uninit_buffer;
1626 
1627 	return 0;
1628 
1629 error_uninit_buffer:
1630 	iio_triggered_buffer_cleanup(indio_dev);
1631 error_disable_reg:
1632 	if (st->vref)
1633 		regulator_disable(st->vref);
1634 	regulator_disable(st->reg);
1635 error_unregister_map:
1636 	iio_map_array_unregister(indio_dev);
1637 	return ret;
1638 }
1639 
1640 static int max1363_remove(struct i2c_client *client)
1641 {
1642 	struct iio_dev *indio_dev = i2c_get_clientdata(client);
1643 	struct max1363_state *st = iio_priv(indio_dev);
1644 
1645 	iio_device_unregister(indio_dev);
1646 	iio_triggered_buffer_cleanup(indio_dev);
1647 	if (st->vref)
1648 		regulator_disable(st->vref);
1649 	regulator_disable(st->reg);
1650 	iio_map_array_unregister(indio_dev);
1651 
1652 	return 0;
1653 }
1654 
1655 static const struct i2c_device_id max1363_id[] = {
1656 	{ "max1361", max1361 },
1657 	{ "max1362", max1362 },
1658 	{ "max1363", max1363 },
1659 	{ "max1364", max1364 },
1660 	{ "max1036", max1036 },
1661 	{ "max1037", max1037 },
1662 	{ "max1038", max1038 },
1663 	{ "max1039", max1039 },
1664 	{ "max1136", max1136 },
1665 	{ "max1137", max1137 },
1666 	{ "max1138", max1138 },
1667 	{ "max1139", max1139 },
1668 	{ "max1236", max1236 },
1669 	{ "max1237", max1237 },
1670 	{ "max1238", max1238 },
1671 	{ "max1239", max1239 },
1672 	{ "max11600", max11600 },
1673 	{ "max11601", max11601 },
1674 	{ "max11602", max11602 },
1675 	{ "max11603", max11603 },
1676 	{ "max11604", max11604 },
1677 	{ "max11605", max11605 },
1678 	{ "max11606", max11606 },
1679 	{ "max11607", max11607 },
1680 	{ "max11608", max11608 },
1681 	{ "max11609", max11609 },
1682 	{ "max11610", max11610 },
1683 	{ "max11611", max11611 },
1684 	{ "max11612", max11612 },
1685 	{ "max11613", max11613 },
1686 	{ "max11614", max11614 },
1687 	{ "max11615", max11615 },
1688 	{ "max11616", max11616 },
1689 	{ "max11617", max11617 },
1690 	{}
1691 };
1692 
1693 MODULE_DEVICE_TABLE(i2c, max1363_id);
1694 
1695 static struct i2c_driver max1363_driver = {
1696 	.driver = {
1697 		.name = "max1363",
1698 	},
1699 	.probe = max1363_probe,
1700 	.remove = max1363_remove,
1701 	.id_table = max1363_id,
1702 };
1703 module_i2c_driver(max1363_driver);
1704 
1705 MODULE_AUTHOR("Jonathan Cameron <jic23@kernel.org>");
1706 MODULE_DESCRIPTION("Maxim 1363 ADC");
1707 MODULE_LICENSE("GPL v2");
1708