dln2-adc.c 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Driver for the Diolan DLN-2 USB-ADC adapter
  4. *
  5. * Copyright (c) 2017 Jack Andersen
  6. */
  7. #include <linux/kernel.h>
  8. #include <linux/module.h>
  9. #include <linux/types.h>
  10. #include <linux/platform_device.h>
  11. #include <linux/mfd/dln2.h>
  12. #include <linux/iio/iio.h>
  13. #include <linux/iio/sysfs.h>
  14. #include <linux/iio/trigger.h>
  15. #include <linux/iio/trigger_consumer.h>
  16. #include <linux/iio/triggered_buffer.h>
  17. #include <linux/iio/buffer.h>
  18. #include <linux/iio/kfifo_buf.h>
  19. #define DLN2_ADC_MOD_NAME "dln2-adc"
  20. #define DLN2_ADC_ID 0x06
  21. #define DLN2_ADC_GET_CHANNEL_COUNT DLN2_CMD(0x01, DLN2_ADC_ID)
  22. #define DLN2_ADC_ENABLE DLN2_CMD(0x02, DLN2_ADC_ID)
  23. #define DLN2_ADC_DISABLE DLN2_CMD(0x03, DLN2_ADC_ID)
  24. #define DLN2_ADC_CHANNEL_ENABLE DLN2_CMD(0x05, DLN2_ADC_ID)
  25. #define DLN2_ADC_CHANNEL_DISABLE DLN2_CMD(0x06, DLN2_ADC_ID)
  26. #define DLN2_ADC_SET_RESOLUTION DLN2_CMD(0x08, DLN2_ADC_ID)
  27. #define DLN2_ADC_CHANNEL_GET_VAL DLN2_CMD(0x0A, DLN2_ADC_ID)
  28. #define DLN2_ADC_CHANNEL_GET_ALL_VAL DLN2_CMD(0x0B, DLN2_ADC_ID)
  29. #define DLN2_ADC_CHANNEL_SET_CFG DLN2_CMD(0x0C, DLN2_ADC_ID)
  30. #define DLN2_ADC_CHANNEL_GET_CFG DLN2_CMD(0x0D, DLN2_ADC_ID)
  31. #define DLN2_ADC_CONDITION_MET_EV DLN2_CMD(0x10, DLN2_ADC_ID)
  32. #define DLN2_ADC_EVENT_NONE 0
  33. #define DLN2_ADC_EVENT_BELOW 1
  34. #define DLN2_ADC_EVENT_LEVEL_ABOVE 2
  35. #define DLN2_ADC_EVENT_OUTSIDE 3
  36. #define DLN2_ADC_EVENT_INSIDE 4
  37. #define DLN2_ADC_EVENT_ALWAYS 5
  38. #define DLN2_ADC_MAX_CHANNELS 8
  39. #define DLN2_ADC_DATA_BITS 10
  40. /*
  41. * Plays similar role to iio_demux_table in subsystem core; except allocated
  42. * in a fixed 8-element array.
  43. */
  44. struct dln2_adc_demux_table {
  45. unsigned int from;
  46. unsigned int to;
  47. unsigned int length;
  48. };
  49. struct dln2_adc {
  50. struct platform_device *pdev;
  51. struct iio_chan_spec iio_channels[DLN2_ADC_MAX_CHANNELS + 1];
  52. int port, trigger_chan;
  53. struct iio_trigger *trig;
  54. struct mutex mutex;
  55. /* Cached sample period in milliseconds */
  56. unsigned int sample_period;
  57. /* Demux table */
  58. unsigned int demux_count;
  59. struct dln2_adc_demux_table demux[DLN2_ADC_MAX_CHANNELS];
  60. };
  61. struct dln2_adc_port_chan {
  62. u8 port;
  63. u8 chan;
  64. };
  65. struct dln2_adc_get_all_vals {
  66. __le16 channel_mask;
  67. __le16 values[DLN2_ADC_MAX_CHANNELS];
  68. };
  69. static void dln2_adc_add_demux(struct dln2_adc *dln2,
  70. unsigned int in_loc, unsigned int out_loc,
  71. unsigned int length)
  72. {
  73. struct dln2_adc_demux_table *p = dln2->demux_count ?
  74. &dln2->demux[dln2->demux_count - 1] : NULL;
  75. if (p && p->from + p->length == in_loc &&
  76. p->to + p->length == out_loc) {
  77. p->length += length;
  78. } else if (dln2->demux_count < DLN2_ADC_MAX_CHANNELS) {
  79. p = &dln2->demux[dln2->demux_count++];
  80. p->from = in_loc;
  81. p->to = out_loc;
  82. p->length = length;
  83. }
  84. }
  85. static void dln2_adc_update_demux(struct dln2_adc *dln2)
  86. {
  87. int in_ind = -1, out_ind;
  88. unsigned int in_loc = 0, out_loc = 0;
  89. struct iio_dev *indio_dev = platform_get_drvdata(dln2->pdev);
  90. /* Clear out any old demux */
  91. dln2->demux_count = 0;
  92. /* Optimize all 8-channels case */
  93. if (iio_get_masklength(indio_dev) &&
  94. (*indio_dev->active_scan_mask & 0xff) == 0xff) {
  95. dln2_adc_add_demux(dln2, 0, 0, 16);
  96. return;
  97. }
  98. /* Build demux table from fixed 8-channels to active_scan_mask */
  99. iio_for_each_active_channel(indio_dev, out_ind) {
  100. /* Handle timestamp separately */
  101. if (out_ind == DLN2_ADC_MAX_CHANNELS)
  102. break;
  103. for (++in_ind; in_ind != out_ind; ++in_ind)
  104. in_loc += 2;
  105. dln2_adc_add_demux(dln2, in_loc, out_loc, 2);
  106. out_loc += 2;
  107. in_loc += 2;
  108. }
  109. }
  110. static int dln2_adc_get_chan_count(struct dln2_adc *dln2)
  111. {
  112. int ret;
  113. u8 port = dln2->port;
  114. u8 count;
  115. int olen = sizeof(count);
  116. ret = dln2_transfer(dln2->pdev, DLN2_ADC_GET_CHANNEL_COUNT,
  117. &port, sizeof(port), &count, &olen);
  118. if (ret < 0) {
  119. dev_dbg(&dln2->pdev->dev, "Problem in %s\n", __func__);
  120. return ret;
  121. }
  122. if (olen < sizeof(count))
  123. return -EPROTO;
  124. return count;
  125. }
  126. static int dln2_adc_set_port_resolution(struct dln2_adc *dln2)
  127. {
  128. int ret;
  129. struct dln2_adc_port_chan port_chan = {
  130. .port = dln2->port,
  131. .chan = DLN2_ADC_DATA_BITS,
  132. };
  133. ret = dln2_transfer_tx(dln2->pdev, DLN2_ADC_SET_RESOLUTION,
  134. &port_chan, sizeof(port_chan));
  135. if (ret < 0)
  136. dev_dbg(&dln2->pdev->dev, "Problem in %s\n", __func__);
  137. return ret;
  138. }
  139. static int dln2_adc_set_chan_enabled(struct dln2_adc *dln2,
  140. int channel, bool enable)
  141. {
  142. int ret;
  143. struct dln2_adc_port_chan port_chan = {
  144. .port = dln2->port,
  145. .chan = channel,
  146. };
  147. u16 cmd = enable ? DLN2_ADC_CHANNEL_ENABLE : DLN2_ADC_CHANNEL_DISABLE;
  148. ret = dln2_transfer_tx(dln2->pdev, cmd, &port_chan, sizeof(port_chan));
  149. if (ret < 0)
  150. dev_dbg(&dln2->pdev->dev, "Problem in %s\n", __func__);
  151. return ret;
  152. }
  153. static int dln2_adc_set_port_enabled(struct dln2_adc *dln2, bool enable,
  154. u16 *conflict_out)
  155. {
  156. int ret;
  157. u8 port = dln2->port;
  158. __le16 conflict;
  159. int olen = sizeof(conflict);
  160. u16 cmd = enable ? DLN2_ADC_ENABLE : DLN2_ADC_DISABLE;
  161. if (conflict_out)
  162. *conflict_out = 0;
  163. ret = dln2_transfer(dln2->pdev, cmd, &port, sizeof(port),
  164. &conflict, &olen);
  165. if (ret < 0) {
  166. dev_dbg(&dln2->pdev->dev, "Problem in %s(%d)\n",
  167. __func__, (int)enable);
  168. if (conflict_out && enable && olen >= sizeof(conflict))
  169. *conflict_out = le16_to_cpu(conflict);
  170. return ret;
  171. }
  172. if (enable && olen < sizeof(conflict))
  173. return -EPROTO;
  174. return ret;
  175. }
  176. static int dln2_adc_set_chan_period(struct dln2_adc *dln2,
  177. unsigned int channel, unsigned int period)
  178. {
  179. int ret;
  180. struct {
  181. struct dln2_adc_port_chan port_chan;
  182. __u8 type;
  183. __le16 period;
  184. __le16 low;
  185. __le16 high;
  186. } __packed set_cfg = {
  187. .port_chan.port = dln2->port,
  188. .port_chan.chan = channel,
  189. .type = period ? DLN2_ADC_EVENT_ALWAYS : DLN2_ADC_EVENT_NONE,
  190. .period = cpu_to_le16(period)
  191. };
  192. ret = dln2_transfer_tx(dln2->pdev, DLN2_ADC_CHANNEL_SET_CFG,
  193. &set_cfg, sizeof(set_cfg));
  194. if (ret < 0)
  195. dev_dbg(&dln2->pdev->dev, "Problem in %s\n", __func__);
  196. return ret;
  197. }
  198. static int dln2_adc_read(struct dln2_adc *dln2, unsigned int channel)
  199. {
  200. int ret, i;
  201. u16 conflict;
  202. __le16 value;
  203. int olen = sizeof(value);
  204. struct dln2_adc_port_chan port_chan = {
  205. .port = dln2->port,
  206. .chan = channel,
  207. };
  208. ret = dln2_adc_set_chan_enabled(dln2, channel, true);
  209. if (ret < 0)
  210. return ret;
  211. ret = dln2_adc_set_port_enabled(dln2, true, &conflict);
  212. if (ret < 0) {
  213. if (conflict) {
  214. dev_err(&dln2->pdev->dev,
  215. "ADC pins conflict with mask %04X\n",
  216. (int)conflict);
  217. ret = -EBUSY;
  218. }
  219. goto disable_chan;
  220. }
  221. /*
  222. * Call GET_VAL twice due to initial zero-return immediately after
  223. * enabling channel.
  224. */
  225. for (i = 0; i < 2; ++i) {
  226. ret = dln2_transfer(dln2->pdev, DLN2_ADC_CHANNEL_GET_VAL,
  227. &port_chan, sizeof(port_chan),
  228. &value, &olen);
  229. if (ret < 0) {
  230. dev_dbg(&dln2->pdev->dev, "Problem in %s\n", __func__);
  231. goto disable_port;
  232. }
  233. if (olen < sizeof(value)) {
  234. ret = -EPROTO;
  235. goto disable_port;
  236. }
  237. }
  238. ret = le16_to_cpu(value);
  239. disable_port:
  240. dln2_adc_set_port_enabled(dln2, false, NULL);
  241. disable_chan:
  242. dln2_adc_set_chan_enabled(dln2, channel, false);
  243. return ret;
  244. }
  245. static int dln2_adc_read_all(struct dln2_adc *dln2,
  246. struct dln2_adc_get_all_vals *get_all_vals)
  247. {
  248. int ret;
  249. __u8 port = dln2->port;
  250. int olen = sizeof(*get_all_vals);
  251. ret = dln2_transfer(dln2->pdev, DLN2_ADC_CHANNEL_GET_ALL_VAL,
  252. &port, sizeof(port), get_all_vals, &olen);
  253. if (ret < 0) {
  254. dev_dbg(&dln2->pdev->dev, "Problem in %s\n", __func__);
  255. return ret;
  256. }
  257. if (olen < sizeof(*get_all_vals))
  258. return -EPROTO;
  259. return ret;
  260. }
  261. static int dln2_adc_read_raw(struct iio_dev *indio_dev,
  262. struct iio_chan_spec const *chan,
  263. int *val,
  264. int *val2,
  265. long mask)
  266. {
  267. int ret;
  268. unsigned int microhertz;
  269. struct dln2_adc *dln2 = iio_priv(indio_dev);
  270. switch (mask) {
  271. case IIO_CHAN_INFO_RAW:
  272. if (!iio_device_claim_direct(indio_dev))
  273. return -EBUSY;
  274. mutex_lock(&dln2->mutex);
  275. ret = dln2_adc_read(dln2, chan->channel);
  276. mutex_unlock(&dln2->mutex);
  277. iio_device_release_direct(indio_dev);
  278. if (ret < 0)
  279. return ret;
  280. *val = ret;
  281. return IIO_VAL_INT;
  282. case IIO_CHAN_INFO_SCALE:
  283. /*
  284. * Voltage reference is fixed at 3.3v
  285. * 3.3 / (1 << 10) * 1000000000
  286. */
  287. *val = 0;
  288. *val2 = 3222656;
  289. return IIO_VAL_INT_PLUS_NANO;
  290. case IIO_CHAN_INFO_SAMP_FREQ:
  291. if (dln2->sample_period) {
  292. microhertz = 1000000000 / dln2->sample_period;
  293. *val = microhertz / 1000000;
  294. *val2 = microhertz % 1000000;
  295. } else {
  296. *val = 0;
  297. *val2 = 0;
  298. }
  299. return IIO_VAL_INT_PLUS_MICRO;
  300. default:
  301. return -EINVAL;
  302. }
  303. }
  304. static int dln2_adc_write_raw(struct iio_dev *indio_dev,
  305. struct iio_chan_spec const *chan,
  306. int val,
  307. int val2,
  308. long mask)
  309. {
  310. int ret;
  311. unsigned int microhertz;
  312. struct dln2_adc *dln2 = iio_priv(indio_dev);
  313. switch (mask) {
  314. case IIO_CHAN_INFO_SAMP_FREQ:
  315. microhertz = 1000000 * val + val2;
  316. mutex_lock(&dln2->mutex);
  317. dln2->sample_period =
  318. microhertz ? 1000000000 / microhertz : UINT_MAX;
  319. if (dln2->sample_period > 65535) {
  320. dln2->sample_period = 65535;
  321. dev_warn(&dln2->pdev->dev,
  322. "clamping period to 65535ms\n");
  323. }
  324. /*
  325. * The first requested channel is arbitrated as a shared
  326. * trigger source, so only one event is registered with the
  327. * DLN. The event handler will then read all enabled channel
  328. * values using DLN2_ADC_CHANNEL_GET_ALL_VAL to maintain
  329. * synchronization between ADC readings.
  330. */
  331. if (dln2->trigger_chan != -1)
  332. ret = dln2_adc_set_chan_period(dln2,
  333. dln2->trigger_chan, dln2->sample_period);
  334. else
  335. ret = 0;
  336. mutex_unlock(&dln2->mutex);
  337. return ret;
  338. default:
  339. return -EINVAL;
  340. }
  341. }
  342. static int dln2_update_scan_mode(struct iio_dev *indio_dev,
  343. const unsigned long *scan_mask)
  344. {
  345. struct dln2_adc *dln2 = iio_priv(indio_dev);
  346. int chan_count = indio_dev->num_channels - 1;
  347. int ret, i, j;
  348. mutex_lock(&dln2->mutex);
  349. for (i = 0; i < chan_count; ++i) {
  350. ret = dln2_adc_set_chan_enabled(dln2, i,
  351. test_bit(i, scan_mask));
  352. if (ret < 0) {
  353. for (j = 0; j < i; ++j)
  354. dln2_adc_set_chan_enabled(dln2, j, false);
  355. mutex_unlock(&dln2->mutex);
  356. dev_err(&dln2->pdev->dev,
  357. "Unable to enable ADC channel %d\n", i);
  358. return -EBUSY;
  359. }
  360. }
  361. dln2_adc_update_demux(dln2);
  362. mutex_unlock(&dln2->mutex);
  363. return 0;
  364. }
  365. #define DLN2_ADC_CHAN(lval, idx) { \
  366. lval.type = IIO_VOLTAGE; \
  367. lval.channel = idx; \
  368. lval.indexed = 1; \
  369. lval.info_mask_separate = BIT(IIO_CHAN_INFO_RAW); \
  370. lval.info_mask_shared_by_all = BIT(IIO_CHAN_INFO_SCALE) | \
  371. BIT(IIO_CHAN_INFO_SAMP_FREQ); \
  372. lval.scan_index = idx; \
  373. lval.scan_type.sign = 'u'; \
  374. lval.scan_type.realbits = DLN2_ADC_DATA_BITS; \
  375. lval.scan_type.storagebits = 16; \
  376. lval.scan_type.endianness = IIO_LE; \
  377. }
  378. /* Assignment version of IIO_CHAN_SOFT_TIMESTAMP */
  379. #define IIO_CHAN_SOFT_TIMESTAMP_ASSIGN(lval, _si) { \
  380. lval.type = IIO_TIMESTAMP; \
  381. lval.channel = -1; \
  382. lval.scan_index = _si; \
  383. lval.scan_type.sign = 's'; \
  384. lval.scan_type.realbits = 64; \
  385. lval.scan_type.storagebits = 64; \
  386. }
  387. static const struct iio_info dln2_adc_info = {
  388. .read_raw = dln2_adc_read_raw,
  389. .write_raw = dln2_adc_write_raw,
  390. .update_scan_mode = dln2_update_scan_mode,
  391. };
  392. static irqreturn_t dln2_adc_trigger_h(int irq, void *p)
  393. {
  394. struct iio_poll_func *pf = p;
  395. struct iio_dev *indio_dev = pf->indio_dev;
  396. struct {
  397. __le16 values[DLN2_ADC_MAX_CHANNELS];
  398. aligned_s64 timestamp_space;
  399. } data = { };
  400. struct dln2_adc_get_all_vals dev_data;
  401. struct dln2_adc *dln2 = iio_priv(indio_dev);
  402. const struct dln2_adc_demux_table *t;
  403. int ret, i;
  404. mutex_lock(&dln2->mutex);
  405. ret = dln2_adc_read_all(dln2, &dev_data);
  406. mutex_unlock(&dln2->mutex);
  407. if (ret < 0)
  408. goto done;
  409. /* Demux operation */
  410. for (i = 0; i < dln2->demux_count; ++i) {
  411. t = &dln2->demux[i];
  412. memcpy((void *)data.values + t->to,
  413. (void *)dev_data.values + t->from, t->length);
  414. }
  415. iio_push_to_buffers_with_ts(indio_dev, &data, sizeof(data),
  416. iio_get_time_ns(indio_dev));
  417. done:
  418. iio_trigger_notify_done(indio_dev->trig);
  419. return IRQ_HANDLED;
  420. }
  421. static int dln2_adc_triggered_buffer_postenable(struct iio_dev *indio_dev)
  422. {
  423. int ret;
  424. struct dln2_adc *dln2 = iio_priv(indio_dev);
  425. u16 conflict;
  426. unsigned int trigger_chan;
  427. mutex_lock(&dln2->mutex);
  428. /* Enable ADC */
  429. ret = dln2_adc_set_port_enabled(dln2, true, &conflict);
  430. if (ret < 0) {
  431. mutex_unlock(&dln2->mutex);
  432. dev_dbg(&dln2->pdev->dev, "Problem in %s\n", __func__);
  433. if (conflict) {
  434. dev_err(&dln2->pdev->dev,
  435. "ADC pins conflict with mask %04X\n",
  436. (int)conflict);
  437. ret = -EBUSY;
  438. }
  439. return ret;
  440. }
  441. /* Assign trigger channel based on first enabled channel */
  442. trigger_chan = find_first_bit(indio_dev->active_scan_mask,
  443. iio_get_masklength(indio_dev));
  444. if (trigger_chan < DLN2_ADC_MAX_CHANNELS) {
  445. dln2->trigger_chan = trigger_chan;
  446. ret = dln2_adc_set_chan_period(dln2, dln2->trigger_chan,
  447. dln2->sample_period);
  448. mutex_unlock(&dln2->mutex);
  449. if (ret < 0) {
  450. dev_dbg(&dln2->pdev->dev, "Problem in %s\n", __func__);
  451. return ret;
  452. }
  453. } else {
  454. dln2->trigger_chan = -1;
  455. mutex_unlock(&dln2->mutex);
  456. }
  457. return 0;
  458. }
  459. static int dln2_adc_triggered_buffer_predisable(struct iio_dev *indio_dev)
  460. {
  461. int ret;
  462. struct dln2_adc *dln2 = iio_priv(indio_dev);
  463. mutex_lock(&dln2->mutex);
  464. /* Disable trigger channel */
  465. if (dln2->trigger_chan != -1) {
  466. dln2_adc_set_chan_period(dln2, dln2->trigger_chan, 0);
  467. dln2->trigger_chan = -1;
  468. }
  469. /* Disable ADC */
  470. ret = dln2_adc_set_port_enabled(dln2, false, NULL);
  471. mutex_unlock(&dln2->mutex);
  472. if (ret < 0)
  473. dev_dbg(&dln2->pdev->dev, "Problem in %s\n", __func__);
  474. return ret;
  475. }
  476. static const struct iio_buffer_setup_ops dln2_adc_buffer_setup_ops = {
  477. .postenable = dln2_adc_triggered_buffer_postenable,
  478. .predisable = dln2_adc_triggered_buffer_predisable,
  479. };
  480. static void dln2_adc_event(struct platform_device *pdev, u16 echo,
  481. const void *data, int len)
  482. {
  483. struct iio_dev *indio_dev = platform_get_drvdata(pdev);
  484. struct dln2_adc *dln2 = iio_priv(indio_dev);
  485. /* Called via URB completion handler */
  486. iio_trigger_poll(dln2->trig);
  487. }
  488. static int dln2_adc_probe(struct platform_device *pdev)
  489. {
  490. struct device *dev = &pdev->dev;
  491. struct dln2_adc *dln2;
  492. struct dln2_platform_data *pdata = dev_get_platdata(&pdev->dev);
  493. struct iio_dev *indio_dev;
  494. int i, ret, chans;
  495. indio_dev = devm_iio_device_alloc(dev, sizeof(*dln2));
  496. if (!indio_dev)
  497. return -ENOMEM;
  498. dln2 = iio_priv(indio_dev);
  499. dln2->pdev = pdev;
  500. dln2->port = pdata->port;
  501. dln2->trigger_chan = -1;
  502. mutex_init(&dln2->mutex);
  503. platform_set_drvdata(pdev, indio_dev);
  504. ret = dln2_adc_set_port_resolution(dln2);
  505. if (ret < 0) {
  506. dev_err(dev, "failed to set ADC resolution to 10 bits\n");
  507. return ret;
  508. }
  509. chans = dln2_adc_get_chan_count(dln2);
  510. if (chans < 0) {
  511. dev_err(dev, "failed to get channel count: %d\n", chans);
  512. return chans;
  513. }
  514. if (chans > DLN2_ADC_MAX_CHANNELS) {
  515. chans = DLN2_ADC_MAX_CHANNELS;
  516. dev_warn(dev, "clamping channels to %d\n",
  517. DLN2_ADC_MAX_CHANNELS);
  518. }
  519. for (i = 0; i < chans; ++i)
  520. DLN2_ADC_CHAN(dln2->iio_channels[i], i)
  521. IIO_CHAN_SOFT_TIMESTAMP_ASSIGN(dln2->iio_channels[i], i);
  522. indio_dev->name = DLN2_ADC_MOD_NAME;
  523. indio_dev->info = &dln2_adc_info;
  524. indio_dev->modes = INDIO_DIRECT_MODE;
  525. indio_dev->channels = dln2->iio_channels;
  526. indio_dev->num_channels = chans + 1;
  527. indio_dev->setup_ops = &dln2_adc_buffer_setup_ops;
  528. dln2->trig = devm_iio_trigger_alloc(dev, "%s-dev%d",
  529. indio_dev->name,
  530. iio_device_id(indio_dev));
  531. if (!dln2->trig)
  532. return -ENOMEM;
  533. iio_trigger_set_drvdata(dln2->trig, dln2);
  534. ret = devm_iio_trigger_register(dev, dln2->trig);
  535. if (ret) {
  536. dev_err(dev, "failed to register trigger: %d\n", ret);
  537. return ret;
  538. }
  539. iio_trigger_set_immutable(indio_dev, dln2->trig);
  540. ret = devm_iio_triggered_buffer_setup(dev, indio_dev, NULL,
  541. dln2_adc_trigger_h,
  542. &dln2_adc_buffer_setup_ops);
  543. if (ret) {
  544. dev_err(dev, "failed to allocate triggered buffer: %d\n", ret);
  545. return ret;
  546. }
  547. ret = dln2_register_event_cb(pdev, DLN2_ADC_CONDITION_MET_EV,
  548. dln2_adc_event);
  549. if (ret) {
  550. dev_err(dev, "failed to setup DLN2 periodic event: %d\n", ret);
  551. return ret;
  552. }
  553. ret = iio_device_register(indio_dev);
  554. if (ret) {
  555. dev_err(dev, "failed to register iio device: %d\n", ret);
  556. goto unregister_event;
  557. }
  558. return ret;
  559. unregister_event:
  560. dln2_unregister_event_cb(pdev, DLN2_ADC_CONDITION_MET_EV);
  561. return ret;
  562. }
  563. static void dln2_adc_remove(struct platform_device *pdev)
  564. {
  565. struct iio_dev *indio_dev = platform_get_drvdata(pdev);
  566. iio_device_unregister(indio_dev);
  567. dln2_unregister_event_cb(pdev, DLN2_ADC_CONDITION_MET_EV);
  568. }
  569. static struct platform_driver dln2_adc_driver = {
  570. .driver.name = DLN2_ADC_MOD_NAME,
  571. .probe = dln2_adc_probe,
  572. .remove = dln2_adc_remove,
  573. };
  574. module_platform_driver(dln2_adc_driver);
  575. MODULE_AUTHOR("Jack Andersen <jackoalan@gmail.com");
  576. MODULE_DESCRIPTION("Driver for the Diolan DLN2 ADC interface");
  577. MODULE_LICENSE("GPL v2");
  578. MODULE_ALIAS("platform:dln2-adc");