ad8460.c 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * AD8460 Waveform generator DAC Driver
  4. *
  5. * Copyright (C) 2024 Analog Devices, Inc.
  6. */
  7. #include <linux/bitfield.h>
  8. #include <linux/cleanup.h>
  9. #include <linux/clk.h>
  10. #include <linux/debugfs.h>
  11. #include <linux/delay.h>
  12. #include <linux/dmaengine.h>
  13. #include <linux/gpio/consumer.h>
  14. #include <linux/kernel.h>
  15. #include <linux/module.h>
  16. #include <linux/mod_devicetable.h>
  17. #include <linux/regmap.h>
  18. #include <linux/regulator/consumer.h>
  19. #include <linux/spi/spi.h>
  20. #include <linux/iio/buffer.h>
  21. #include <linux/iio/buffer-dma.h>
  22. #include <linux/iio/buffer-dmaengine.h>
  23. #include <linux/iio/consumer.h>
  24. #include <linux/iio/events.h>
  25. #include <linux/iio/iio.h>
  26. #define AD8460_CTRL_REG(x) (x)
  27. #define AD8460_HVDAC_DATA_WORD(x) (0x60 + (2 * (x)))
  28. #define AD8460_HV_RESET_MSK BIT(7)
  29. #define AD8460_HV_SLEEP_MSK BIT(4)
  30. #define AD8460_WAVE_GEN_MODE_MSK BIT(0)
  31. #define AD8460_HVDAC_SLEEP_MSK BIT(3)
  32. #define AD8460_FAULT_ARM_MSK BIT(7)
  33. #define AD8460_FAULT_LIMIT_MSK GENMASK(6, 0)
  34. #define AD8460_APG_MODE_ENABLE_MSK BIT(5)
  35. #define AD8460_PATTERN_DEPTH_MSK GENMASK(3, 0)
  36. #define AD8460_QUIESCENT_CURRENT_MSK GENMASK(7, 0)
  37. #define AD8460_SHUTDOWN_FLAG_MSK BIT(7)
  38. #define AD8460_DATA_BYTE_LOW_MSK GENMASK(7, 0)
  39. #define AD8460_DATA_BYTE_HIGH_MSK GENMASK(5, 0)
  40. #define AD8460_DATA_BYTE_FULL_MSK GENMASK(13, 0)
  41. #define AD8460_DEFAULT_FAULT_PROTECT 0x00
  42. #define AD8460_DATA_BYTE_WORD_LENGTH 2
  43. #define AD8460_NUM_DATA_WORDS 16
  44. #define AD8460_NOMINAL_VOLTAGE_SPAN 80
  45. #define AD8460_MIN_EXT_RESISTOR_OHMS 2000
  46. #define AD8460_MAX_EXT_RESISTOR_OHMS 20000
  47. #define AD8460_MIN_VREFIO_UV 120000
  48. #define AD8460_MAX_VREFIO_UV 1200000
  49. #define AD8460_ABS_MAX_OVERVOLTAGE_UV 55000000
  50. #define AD8460_ABS_MAX_OVERCURRENT_UA 1000000
  51. #define AD8460_MAX_OVERTEMPERATURE_MC 150000
  52. #define AD8460_MIN_OVERTEMPERATURE_MC 20000
  53. #define AD8460_CURRENT_LIMIT_CONV(x) ((x) / 15625)
  54. #define AD8460_VOLTAGE_LIMIT_CONV(x) ((x) / 1953000)
  55. #define AD8460_TEMP_LIMIT_CONV(x) (((x) + 266640) / 6510)
  56. enum ad8460_fault_type {
  57. AD8460_OVERCURRENT_SRC,
  58. AD8460_OVERCURRENT_SNK,
  59. AD8460_OVERVOLTAGE_POS,
  60. AD8460_OVERVOLTAGE_NEG,
  61. AD8460_OVERTEMPERATURE,
  62. };
  63. struct ad8460_state {
  64. struct spi_device *spi;
  65. struct regmap *regmap;
  66. struct iio_channel *tmp_adc_channel;
  67. struct clk *sync_clk;
  68. /* lock to protect against multiple access to the device and shared data */
  69. struct mutex lock;
  70. int refio_1p2v_mv;
  71. u32 ext_resistor_ohms;
  72. /*
  73. * DMA (thus cache coherency maintenance) requires the
  74. * transfer buffers to live in their own cache lines.
  75. */
  76. __le16 spi_tx_buf __aligned(IIO_DMA_MINALIGN);
  77. };
  78. static int ad8460_hv_reset(struct ad8460_state *state)
  79. {
  80. int ret;
  81. ret = regmap_set_bits(state->regmap, AD8460_CTRL_REG(0x00),
  82. AD8460_HV_RESET_MSK);
  83. if (ret)
  84. return ret;
  85. fsleep(20);
  86. return regmap_clear_bits(state->regmap, AD8460_CTRL_REG(0x00),
  87. AD8460_HV_RESET_MSK);
  88. }
  89. static int ad8460_reset(const struct ad8460_state *state)
  90. {
  91. struct device *dev = &state->spi->dev;
  92. struct gpio_desc *reset;
  93. reset = devm_gpiod_get_optional(dev, "reset", GPIOD_OUT_LOW);
  94. if (IS_ERR(reset))
  95. return dev_err_probe(dev, PTR_ERR(reset),
  96. "Failed to get reset gpio");
  97. if (reset) {
  98. /* minimum duration of 10ns */
  99. ndelay(10);
  100. gpiod_set_value_cansleep(reset, 1);
  101. return 0;
  102. }
  103. /* bring all registers to their default state */
  104. return regmap_write(state->regmap, AD8460_CTRL_REG(0x03), 1);
  105. }
  106. static int ad8460_enable_apg_mode(struct ad8460_state *state, int val)
  107. {
  108. int ret;
  109. ret = regmap_update_bits(state->regmap, AD8460_CTRL_REG(0x02),
  110. AD8460_APG_MODE_ENABLE_MSK,
  111. FIELD_PREP(AD8460_APG_MODE_ENABLE_MSK, val));
  112. if (ret)
  113. return ret;
  114. return regmap_update_bits(state->regmap, AD8460_CTRL_REG(0x00),
  115. AD8460_WAVE_GEN_MODE_MSK,
  116. FIELD_PREP(AD8460_WAVE_GEN_MODE_MSK, val));
  117. }
  118. static int ad8460_read_shutdown_flag(struct ad8460_state *state, u64 *flag)
  119. {
  120. int ret, val;
  121. ret = regmap_read(state->regmap, AD8460_CTRL_REG(0x0E), &val);
  122. if (ret)
  123. return ret;
  124. *flag = FIELD_GET(AD8460_SHUTDOWN_FLAG_MSK, val);
  125. return 0;
  126. }
  127. static int ad8460_get_hvdac_word(struct ad8460_state *state, int index, int *val)
  128. {
  129. int ret;
  130. ret = regmap_bulk_read(state->regmap, AD8460_HVDAC_DATA_WORD(index),
  131. &state->spi_tx_buf, AD8460_DATA_BYTE_WORD_LENGTH);
  132. if (ret)
  133. return ret;
  134. *val = le16_to_cpu(state->spi_tx_buf);
  135. return ret;
  136. }
  137. static int ad8460_set_hvdac_word(struct ad8460_state *state, int index, int val)
  138. {
  139. state->spi_tx_buf = cpu_to_le16(FIELD_PREP(AD8460_DATA_BYTE_FULL_MSK, val));
  140. return regmap_bulk_write(state->regmap, AD8460_HVDAC_DATA_WORD(index),
  141. &state->spi_tx_buf, AD8460_DATA_BYTE_WORD_LENGTH);
  142. }
  143. static ssize_t ad8460_dac_input_read(struct iio_dev *indio_dev, uintptr_t private,
  144. const struct iio_chan_spec *chan, char *buf)
  145. {
  146. struct ad8460_state *state = iio_priv(indio_dev);
  147. unsigned int reg;
  148. int ret;
  149. ret = ad8460_get_hvdac_word(state, private, &reg);
  150. if (ret)
  151. return ret;
  152. return sysfs_emit(buf, "%u\n", reg);
  153. }
  154. static ssize_t ad8460_dac_input_write(struct iio_dev *indio_dev, uintptr_t private,
  155. const struct iio_chan_spec *chan,
  156. const char *buf, size_t len)
  157. {
  158. struct ad8460_state *state = iio_priv(indio_dev);
  159. unsigned int reg;
  160. int ret;
  161. ret = kstrtou32(buf, 10, &reg);
  162. if (ret)
  163. return ret;
  164. guard(mutex)(&state->lock);
  165. return ad8460_set_hvdac_word(state, private, reg);
  166. }
  167. static ssize_t ad8460_read_symbol(struct iio_dev *indio_dev, uintptr_t private,
  168. const struct iio_chan_spec *chan, char *buf)
  169. {
  170. struct ad8460_state *state = iio_priv(indio_dev);
  171. unsigned int reg;
  172. int ret;
  173. ret = regmap_read(state->regmap, AD8460_CTRL_REG(0x02), &reg);
  174. if (ret)
  175. return ret;
  176. return sysfs_emit(buf, "%lu\n", FIELD_GET(AD8460_PATTERN_DEPTH_MSK, reg));
  177. }
  178. static ssize_t ad8460_write_symbol(struct iio_dev *indio_dev, uintptr_t private,
  179. const struct iio_chan_spec *chan,
  180. const char *buf, size_t len)
  181. {
  182. struct ad8460_state *state = iio_priv(indio_dev);
  183. uint16_t sym;
  184. int ret;
  185. ret = kstrtou16(buf, 10, &sym);
  186. if (ret)
  187. return ret;
  188. guard(mutex)(&state->lock);
  189. return regmap_update_bits(state->regmap,
  190. AD8460_CTRL_REG(0x02),
  191. AD8460_PATTERN_DEPTH_MSK,
  192. FIELD_PREP(AD8460_PATTERN_DEPTH_MSK, sym));
  193. }
  194. static ssize_t ad8460_read_toggle_en(struct iio_dev *indio_dev, uintptr_t private,
  195. const struct iio_chan_spec *chan, char *buf)
  196. {
  197. struct ad8460_state *state = iio_priv(indio_dev);
  198. unsigned int reg;
  199. int ret;
  200. ret = regmap_read(state->regmap, AD8460_CTRL_REG(0x02), &reg);
  201. if (ret)
  202. return ret;
  203. return sysfs_emit(buf, "%ld\n", FIELD_GET(AD8460_APG_MODE_ENABLE_MSK, reg));
  204. }
  205. static ssize_t ad8460_write_toggle_en(struct iio_dev *indio_dev, uintptr_t private,
  206. const struct iio_chan_spec *chan,
  207. const char *buf, size_t len)
  208. {
  209. struct ad8460_state *state = iio_priv(indio_dev);
  210. bool toggle_en;
  211. int ret;
  212. ret = kstrtobool(buf, &toggle_en);
  213. if (ret)
  214. return ret;
  215. if (!iio_device_claim_direct(indio_dev))
  216. return -EBUSY;
  217. ret = ad8460_enable_apg_mode(state, toggle_en);
  218. iio_device_release_direct(indio_dev);
  219. return ret;
  220. }
  221. static ssize_t ad8460_read_powerdown(struct iio_dev *indio_dev, uintptr_t private,
  222. const struct iio_chan_spec *chan, char *buf)
  223. {
  224. struct ad8460_state *state = iio_priv(indio_dev);
  225. unsigned int reg;
  226. int ret;
  227. ret = regmap_read(state->regmap, AD8460_CTRL_REG(0x01), &reg);
  228. if (ret)
  229. return ret;
  230. return sysfs_emit(buf, "%ld\n", FIELD_GET(AD8460_HVDAC_SLEEP_MSK, reg));
  231. }
  232. static ssize_t ad8460_write_powerdown(struct iio_dev *indio_dev, uintptr_t private,
  233. const struct iio_chan_spec *chan,
  234. const char *buf, size_t len)
  235. {
  236. struct ad8460_state *state = iio_priv(indio_dev);
  237. bool pwr_down;
  238. u64 sdn_flag;
  239. int ret;
  240. ret = kstrtobool(buf, &pwr_down);
  241. if (ret)
  242. return ret;
  243. guard(mutex)(&state->lock);
  244. /*
  245. * If powerdown is set, HVDAC is enabled and the HV driver is
  246. * enabled via HV_RESET in case it is in shutdown mode,
  247. * If powerdown is cleared, HVDAC is set to shutdown state
  248. * as well as the HV driver. Quiescent current decreases and ouput is
  249. * floating (high impedance).
  250. */
  251. ret = regmap_update_bits(state->regmap, AD8460_CTRL_REG(0x01),
  252. AD8460_HVDAC_SLEEP_MSK,
  253. FIELD_PREP(AD8460_HVDAC_SLEEP_MSK, pwr_down));
  254. if (ret)
  255. return ret;
  256. if (!pwr_down) {
  257. ret = ad8460_read_shutdown_flag(state, &sdn_flag);
  258. if (ret)
  259. return ret;
  260. if (sdn_flag) {
  261. ret = ad8460_hv_reset(state);
  262. if (ret)
  263. return ret;
  264. }
  265. }
  266. ret = regmap_update_bits(state->regmap, AD8460_CTRL_REG(0x00),
  267. AD8460_HV_SLEEP_MSK,
  268. FIELD_PREP(AD8460_HV_SLEEP_MSK, !pwr_down));
  269. if (ret)
  270. return ret;
  271. return len;
  272. }
  273. static const char * const ad8460_powerdown_modes[] = {
  274. "three_state",
  275. };
  276. static int ad8460_get_powerdown_mode(struct iio_dev *indio_dev,
  277. const struct iio_chan_spec *chan)
  278. {
  279. return 0;
  280. }
  281. static int ad8460_set_powerdown_mode(struct iio_dev *indio_dev,
  282. const struct iio_chan_spec *chan,
  283. unsigned int type)
  284. {
  285. return 0;
  286. }
  287. static int ad8460_set_sample(struct ad8460_state *state, int val)
  288. {
  289. int ret;
  290. ret = ad8460_enable_apg_mode(state, 1);
  291. if (ret)
  292. return ret;
  293. guard(mutex)(&state->lock);
  294. ret = ad8460_set_hvdac_word(state, 0, val);
  295. if (ret)
  296. return ret;
  297. return regmap_update_bits(state->regmap, AD8460_CTRL_REG(0x02),
  298. AD8460_PATTERN_DEPTH_MSK,
  299. FIELD_PREP(AD8460_PATTERN_DEPTH_MSK, 0));
  300. }
  301. static int ad8460_set_fault_threshold(struct ad8460_state *state,
  302. enum ad8460_fault_type fault,
  303. unsigned int threshold)
  304. {
  305. return regmap_update_bits(state->regmap, AD8460_CTRL_REG(0x08 + fault),
  306. AD8460_FAULT_LIMIT_MSK,
  307. FIELD_PREP(AD8460_FAULT_LIMIT_MSK, threshold));
  308. }
  309. static int ad8460_get_fault_threshold(struct ad8460_state *state,
  310. enum ad8460_fault_type fault,
  311. unsigned int *threshold)
  312. {
  313. unsigned int val;
  314. int ret;
  315. ret = regmap_read(state->regmap, AD8460_CTRL_REG(0x08 + fault), &val);
  316. if (ret)
  317. return ret;
  318. *threshold = FIELD_GET(AD8460_FAULT_LIMIT_MSK, val);
  319. return ret;
  320. }
  321. static int ad8460_set_fault_threshold_en(struct ad8460_state *state,
  322. enum ad8460_fault_type fault, bool en)
  323. {
  324. return regmap_update_bits(state->regmap, AD8460_CTRL_REG(0x08 + fault),
  325. AD8460_FAULT_ARM_MSK,
  326. FIELD_PREP(AD8460_FAULT_ARM_MSK, en));
  327. }
  328. static int ad8460_get_fault_threshold_en(struct ad8460_state *state,
  329. enum ad8460_fault_type fault, bool *en)
  330. {
  331. unsigned int val;
  332. int ret;
  333. ret = regmap_read(state->regmap, AD8460_CTRL_REG(0x08 + fault), &val);
  334. if (ret)
  335. return ret;
  336. *en = FIELD_GET(AD8460_FAULT_ARM_MSK, val);
  337. return 0;
  338. }
  339. static int ad8460_write_raw(struct iio_dev *indio_dev,
  340. struct iio_chan_spec const *chan, int val, int val2,
  341. long mask)
  342. {
  343. struct ad8460_state *state = iio_priv(indio_dev);
  344. int ret;
  345. switch (mask) {
  346. case IIO_CHAN_INFO_RAW:
  347. switch (chan->type) {
  348. case IIO_VOLTAGE:
  349. if (!iio_device_claim_direct(indio_dev))
  350. return -EBUSY;
  351. ret = ad8460_set_sample(state, val);
  352. iio_device_release_direct(indio_dev);
  353. return ret;
  354. case IIO_CURRENT:
  355. return regmap_write(state->regmap, AD8460_CTRL_REG(0x04),
  356. FIELD_PREP(AD8460_QUIESCENT_CURRENT_MSK, val));
  357. default:
  358. return -EINVAL;
  359. }
  360. default:
  361. return -EINVAL;
  362. }
  363. }
  364. static int ad8460_read_raw(struct iio_dev *indio_dev, struct iio_chan_spec const *chan,
  365. int *val, int *val2, long mask)
  366. {
  367. struct ad8460_state *state = iio_priv(indio_dev);
  368. int data, ret;
  369. switch (mask) {
  370. case IIO_CHAN_INFO_RAW:
  371. switch (chan->type) {
  372. case IIO_VOLTAGE:
  373. scoped_guard(mutex, &state->lock) {
  374. ret = ad8460_get_hvdac_word(state, 0, &data);
  375. if (ret)
  376. return ret;
  377. }
  378. *val = data;
  379. return IIO_VAL_INT;
  380. case IIO_CURRENT:
  381. ret = regmap_read(state->regmap, AD8460_CTRL_REG(0x04),
  382. &data);
  383. if (ret)
  384. return ret;
  385. *val = data;
  386. return IIO_VAL_INT;
  387. case IIO_TEMP:
  388. ret = iio_read_channel_raw(state->tmp_adc_channel, &data);
  389. if (ret)
  390. return ret;
  391. *val = data;
  392. return IIO_VAL_INT;
  393. default:
  394. return -EINVAL;
  395. }
  396. case IIO_CHAN_INFO_SAMP_FREQ:
  397. *val = clk_get_rate(state->sync_clk);
  398. return IIO_VAL_INT;
  399. case IIO_CHAN_INFO_SCALE:
  400. /*
  401. * vCONV = vNOMINAL_SPAN * (DAC_CODE / 2**14) - 40V
  402. * vMAX = vNOMINAL_SPAN * (2**14 / 2**14) - 40V
  403. * vMIN = vNOMINAL_SPAN * (0 / 2**14) - 40V
  404. * vADJ = vCONV * (2000 / rSET) * (vREF / 1.2)
  405. * vSPAN = vADJ_MAX - vADJ_MIN
  406. * See datasheet page 49, section FULL-SCALE REDUCTION
  407. */
  408. *val = AD8460_NOMINAL_VOLTAGE_SPAN * 2000 * state->refio_1p2v_mv;
  409. *val2 = state->ext_resistor_ohms * 1200;
  410. return IIO_VAL_FRACTIONAL;
  411. default:
  412. return -EINVAL;
  413. }
  414. }
  415. static int ad8460_select_fault_type(int chan_type, enum iio_event_direction dir)
  416. {
  417. switch (chan_type) {
  418. case IIO_VOLTAGE:
  419. switch (dir) {
  420. case IIO_EV_DIR_RISING:
  421. return AD8460_OVERVOLTAGE_POS;
  422. case IIO_EV_DIR_FALLING:
  423. return AD8460_OVERVOLTAGE_NEG;
  424. default:
  425. return -EINVAL;
  426. }
  427. case IIO_CURRENT:
  428. switch (dir) {
  429. case IIO_EV_DIR_RISING:
  430. return AD8460_OVERCURRENT_SRC;
  431. case IIO_EV_DIR_FALLING:
  432. return AD8460_OVERCURRENT_SNK;
  433. default:
  434. return -EINVAL;
  435. }
  436. case IIO_TEMP:
  437. switch (dir) {
  438. case IIO_EV_DIR_RISING:
  439. return AD8460_OVERTEMPERATURE;
  440. default:
  441. return -EINVAL;
  442. }
  443. default:
  444. return -EINVAL;
  445. }
  446. }
  447. static int ad8460_write_event_value(struct iio_dev *indio_dev,
  448. const struct iio_chan_spec *chan,
  449. enum iio_event_type type,
  450. enum iio_event_direction dir,
  451. enum iio_event_info info, int val, int val2)
  452. {
  453. struct ad8460_state *state = iio_priv(indio_dev);
  454. int fault;
  455. if (type != IIO_EV_TYPE_THRESH)
  456. return -EINVAL;
  457. if (info != IIO_EV_INFO_VALUE)
  458. return -EINVAL;
  459. fault = ad8460_select_fault_type(chan->type, dir);
  460. if (fault < 0)
  461. return fault;
  462. return ad8460_set_fault_threshold(state, fault, val);
  463. }
  464. static int ad8460_read_event_value(struct iio_dev *indio_dev,
  465. const struct iio_chan_spec *chan,
  466. enum iio_event_type type,
  467. enum iio_event_direction dir,
  468. enum iio_event_info info, int *val, int *val2)
  469. {
  470. struct ad8460_state *state = iio_priv(indio_dev);
  471. int fault;
  472. if (type != IIO_EV_TYPE_THRESH)
  473. return -EINVAL;
  474. if (info != IIO_EV_INFO_VALUE)
  475. return -EINVAL;
  476. fault = ad8460_select_fault_type(chan->type, dir);
  477. if (fault < 0)
  478. return fault;
  479. return ad8460_get_fault_threshold(state, fault, val);
  480. }
  481. static int ad8460_write_event_config(struct iio_dev *indio_dev,
  482. const struct iio_chan_spec *chan,
  483. enum iio_event_type type,
  484. enum iio_event_direction dir, bool val)
  485. {
  486. struct ad8460_state *state = iio_priv(indio_dev);
  487. int fault;
  488. if (type != IIO_EV_TYPE_THRESH)
  489. return -EINVAL;
  490. fault = ad8460_select_fault_type(chan->type, dir);
  491. if (fault < 0)
  492. return fault;
  493. return ad8460_set_fault_threshold_en(state, fault, val);
  494. }
  495. static int ad8460_read_event_config(struct iio_dev *indio_dev,
  496. const struct iio_chan_spec *chan,
  497. enum iio_event_type type,
  498. enum iio_event_direction dir)
  499. {
  500. struct ad8460_state *state = iio_priv(indio_dev);
  501. int fault, ret;
  502. bool en;
  503. if (type != IIO_EV_TYPE_THRESH)
  504. return -EINVAL;
  505. fault = ad8460_select_fault_type(chan->type, dir);
  506. if (fault < 0)
  507. return fault;
  508. ret = ad8460_get_fault_threshold_en(state, fault, &en);
  509. if (ret)
  510. return ret;
  511. return en;
  512. }
  513. static int ad8460_reg_access(struct iio_dev *indio_dev, unsigned int reg,
  514. unsigned int writeval, unsigned int *readval)
  515. {
  516. struct ad8460_state *state = iio_priv(indio_dev);
  517. if (readval)
  518. return regmap_read(state->regmap, reg, readval);
  519. return regmap_write(state->regmap, reg, writeval);
  520. }
  521. static int ad8460_buffer_preenable(struct iio_dev *indio_dev)
  522. {
  523. struct ad8460_state *state = iio_priv(indio_dev);
  524. return ad8460_enable_apg_mode(state, 0);
  525. }
  526. static int ad8460_buffer_postdisable(struct iio_dev *indio_dev)
  527. {
  528. struct ad8460_state *state = iio_priv(indio_dev);
  529. return ad8460_enable_apg_mode(state, 1);
  530. }
  531. static const struct iio_buffer_setup_ops ad8460_buffer_setup_ops = {
  532. .preenable = &ad8460_buffer_preenable,
  533. .postdisable = &ad8460_buffer_postdisable,
  534. };
  535. static const struct iio_info ad8460_info = {
  536. .read_raw = &ad8460_read_raw,
  537. .write_raw = &ad8460_write_raw,
  538. .write_event_value = &ad8460_write_event_value,
  539. .read_event_value = &ad8460_read_event_value,
  540. .write_event_config = &ad8460_write_event_config,
  541. .read_event_config = &ad8460_read_event_config,
  542. .debugfs_reg_access = &ad8460_reg_access,
  543. };
  544. static const struct iio_enum ad8460_powerdown_mode_enum = {
  545. .items = ad8460_powerdown_modes,
  546. .num_items = ARRAY_SIZE(ad8460_powerdown_modes),
  547. .get = ad8460_get_powerdown_mode,
  548. .set = ad8460_set_powerdown_mode,
  549. };
  550. #define AD8460_CHAN_EXT_INFO(_name, _what, _read, _write) { \
  551. .name = (_name), \
  552. .read = (_read), \
  553. .write = (_write), \
  554. .private = (_what), \
  555. .shared = IIO_SEPARATE, \
  556. }
  557. static const struct iio_chan_spec_ext_info ad8460_ext_info[] = {
  558. AD8460_CHAN_EXT_INFO("raw0", 0, ad8460_dac_input_read,
  559. ad8460_dac_input_write),
  560. AD8460_CHAN_EXT_INFO("raw1", 1, ad8460_dac_input_read,
  561. ad8460_dac_input_write),
  562. AD8460_CHAN_EXT_INFO("raw2", 2, ad8460_dac_input_read,
  563. ad8460_dac_input_write),
  564. AD8460_CHAN_EXT_INFO("raw3", 3, ad8460_dac_input_read,
  565. ad8460_dac_input_write),
  566. AD8460_CHAN_EXT_INFO("raw4", 4, ad8460_dac_input_read,
  567. ad8460_dac_input_write),
  568. AD8460_CHAN_EXT_INFO("raw5", 5, ad8460_dac_input_read,
  569. ad8460_dac_input_write),
  570. AD8460_CHAN_EXT_INFO("raw6", 6, ad8460_dac_input_read,
  571. ad8460_dac_input_write),
  572. AD8460_CHAN_EXT_INFO("raw7", 7, ad8460_dac_input_read,
  573. ad8460_dac_input_write),
  574. AD8460_CHAN_EXT_INFO("raw8", 8, ad8460_dac_input_read,
  575. ad8460_dac_input_write),
  576. AD8460_CHAN_EXT_INFO("raw9", 9, ad8460_dac_input_read,
  577. ad8460_dac_input_write),
  578. AD8460_CHAN_EXT_INFO("raw10", 10, ad8460_dac_input_read,
  579. ad8460_dac_input_write),
  580. AD8460_CHAN_EXT_INFO("raw11", 11, ad8460_dac_input_read,
  581. ad8460_dac_input_write),
  582. AD8460_CHAN_EXT_INFO("raw12", 12, ad8460_dac_input_read,
  583. ad8460_dac_input_write),
  584. AD8460_CHAN_EXT_INFO("raw13", 13, ad8460_dac_input_read,
  585. ad8460_dac_input_write),
  586. AD8460_CHAN_EXT_INFO("raw14", 14, ad8460_dac_input_read,
  587. ad8460_dac_input_write),
  588. AD8460_CHAN_EXT_INFO("raw15", 15, ad8460_dac_input_read,
  589. ad8460_dac_input_write),
  590. AD8460_CHAN_EXT_INFO("toggle_en", 0, ad8460_read_toggle_en,
  591. ad8460_write_toggle_en),
  592. AD8460_CHAN_EXT_INFO("symbol", 0, ad8460_read_symbol,
  593. ad8460_write_symbol),
  594. AD8460_CHAN_EXT_INFO("powerdown", 0, ad8460_read_powerdown,
  595. ad8460_write_powerdown),
  596. IIO_ENUM("powerdown_mode", IIO_SEPARATE, &ad8460_powerdown_mode_enum),
  597. IIO_ENUM_AVAILABLE("powerdown_mode", IIO_SHARED_BY_TYPE,
  598. &ad8460_powerdown_mode_enum),
  599. { }
  600. };
  601. static const struct iio_event_spec ad8460_events[] = {
  602. {
  603. .type = IIO_EV_TYPE_THRESH,
  604. .dir = IIO_EV_DIR_RISING,
  605. .mask_separate = BIT(IIO_EV_INFO_VALUE) |
  606. BIT(IIO_EV_INFO_ENABLE),
  607. },
  608. {
  609. .type = IIO_EV_TYPE_THRESH,
  610. .dir = IIO_EV_DIR_FALLING,
  611. .mask_separate = BIT(IIO_EV_INFO_VALUE) |
  612. BIT(IIO_EV_INFO_ENABLE),
  613. },
  614. };
  615. #define AD8460_VOLTAGE_CHAN { \
  616. .type = IIO_VOLTAGE, \
  617. .info_mask_separate = BIT(IIO_CHAN_INFO_SAMP_FREQ) | \
  618. BIT(IIO_CHAN_INFO_RAW) | \
  619. BIT(IIO_CHAN_INFO_SCALE), \
  620. .output = 1, \
  621. .indexed = 1, \
  622. .channel = 0, \
  623. .scan_index = 0, \
  624. .scan_type = { \
  625. .sign = 'u', \
  626. .realbits = 14, \
  627. .storagebits = 16, \
  628. .endianness = IIO_CPU, \
  629. }, \
  630. .ext_info = ad8460_ext_info, \
  631. .event_spec = ad8460_events, \
  632. .num_event_specs = ARRAY_SIZE(ad8460_events), \
  633. }
  634. #define AD8460_CURRENT_CHAN { \
  635. .type = IIO_CURRENT, \
  636. .info_mask_separate = BIT(IIO_CHAN_INFO_RAW), \
  637. .output = 1, \
  638. .indexed = 1, \
  639. .channel = 0, \
  640. .scan_index = -1, \
  641. .event_spec = ad8460_events, \
  642. .num_event_specs = ARRAY_SIZE(ad8460_events), \
  643. }
  644. #define AD8460_TEMP_CHAN { \
  645. .type = IIO_TEMP, \
  646. .info_mask_separate = BIT(IIO_CHAN_INFO_RAW), \
  647. .indexed = 1, \
  648. .channel = 0, \
  649. .scan_index = -1, \
  650. .event_spec = ad8460_events, \
  651. .num_event_specs = 1, \
  652. }
  653. static const struct iio_chan_spec ad8460_channels[] = {
  654. AD8460_VOLTAGE_CHAN,
  655. AD8460_CURRENT_CHAN,
  656. };
  657. static const struct iio_chan_spec ad8460_channels_with_tmp_adc[] = {
  658. AD8460_VOLTAGE_CHAN,
  659. AD8460_CURRENT_CHAN,
  660. AD8460_TEMP_CHAN,
  661. };
  662. static const struct regmap_config ad8460_regmap_config = {
  663. .reg_bits = 8,
  664. .val_bits = 8,
  665. .max_register = 0x7F,
  666. };
  667. static const char * const ad8460_supplies[] = {
  668. "avdd_3p3v", "dvdd_3p3v", "vcc_5v", "hvcc", "hvee", "vref_5v"
  669. };
  670. static int ad8460_probe(struct spi_device *spi)
  671. {
  672. struct device *dev = &spi->dev;
  673. struct ad8460_state *state;
  674. struct iio_dev *indio_dev;
  675. u32 tmp[2], temp;
  676. int ret;
  677. indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*state));
  678. if (!indio_dev)
  679. return -ENOMEM;
  680. state = iio_priv(indio_dev);
  681. indio_dev->name = "ad8460";
  682. indio_dev->info = &ad8460_info;
  683. state->spi = spi;
  684. state->regmap = devm_regmap_init_spi(spi, &ad8460_regmap_config);
  685. if (IS_ERR(state->regmap))
  686. return dev_err_probe(dev, PTR_ERR(state->regmap),
  687. "Failed to initialize regmap");
  688. ret = devm_mutex_init(dev, &state->lock);
  689. if (ret)
  690. return ret;
  691. state->sync_clk = devm_clk_get_enabled(dev, NULL);
  692. if (IS_ERR(state->sync_clk))
  693. return dev_err_probe(dev, PTR_ERR(state->sync_clk),
  694. "Failed to get sync clk\n");
  695. state->tmp_adc_channel = devm_iio_channel_get(dev, "ad8460-tmp");
  696. if (IS_ERR(state->tmp_adc_channel)) {
  697. if (PTR_ERR(state->tmp_adc_channel) == -EPROBE_DEFER)
  698. return -EPROBE_DEFER;
  699. indio_dev->channels = ad8460_channels;
  700. indio_dev->num_channels = ARRAY_SIZE(ad8460_channels);
  701. } else {
  702. indio_dev->channels = ad8460_channels_with_tmp_adc;
  703. indio_dev->num_channels = ARRAY_SIZE(ad8460_channels_with_tmp_adc);
  704. }
  705. ret = devm_regulator_bulk_get_enable(dev, ARRAY_SIZE(ad8460_supplies),
  706. ad8460_supplies);
  707. if (ret)
  708. return dev_err_probe(dev, ret,
  709. "Failed to enable power supplies\n");
  710. ret = devm_regulator_get_enable_read_voltage(dev, "refio_1p2v");
  711. if (ret < 0 && ret != -ENODEV)
  712. return dev_err_probe(dev, ret, "Failed to get reference voltage\n");
  713. state->refio_1p2v_mv = ret == -ENODEV ? 1200 : ret / 1000;
  714. if (!in_range(state->refio_1p2v_mv, AD8460_MIN_VREFIO_UV / 1000,
  715. AD8460_MAX_VREFIO_UV / 1000))
  716. return dev_err_probe(dev, -EINVAL,
  717. "Invalid ref voltage range(%u mV) [%u mV, %u mV]\n",
  718. state->refio_1p2v_mv,
  719. AD8460_MIN_VREFIO_UV / 1000,
  720. AD8460_MAX_VREFIO_UV / 1000);
  721. ret = device_property_read_u32(dev, "adi,external-resistor-ohms",
  722. &state->ext_resistor_ohms);
  723. if (ret)
  724. state->ext_resistor_ohms = 2000;
  725. else if (!in_range(state->ext_resistor_ohms, AD8460_MIN_EXT_RESISTOR_OHMS,
  726. AD8460_MAX_EXT_RESISTOR_OHMS))
  727. return dev_err_probe(dev, -EINVAL,
  728. "Invalid resistor set range(%u) [%u, %u]\n",
  729. state->ext_resistor_ohms,
  730. AD8460_MIN_EXT_RESISTOR_OHMS,
  731. AD8460_MAX_EXT_RESISTOR_OHMS);
  732. ret = device_property_read_u32_array(dev, "adi,range-microamp",
  733. tmp, ARRAY_SIZE(tmp));
  734. if (!ret) {
  735. if (in_range(tmp[1], 0, AD8460_ABS_MAX_OVERCURRENT_UA))
  736. regmap_write(state->regmap, AD8460_CTRL_REG(0x08),
  737. FIELD_PREP(AD8460_FAULT_ARM_MSK, 1) |
  738. AD8460_CURRENT_LIMIT_CONV(tmp[1]));
  739. if (in_range(tmp[0], -AD8460_ABS_MAX_OVERCURRENT_UA, 0))
  740. regmap_write(state->regmap, AD8460_CTRL_REG(0x09),
  741. FIELD_PREP(AD8460_FAULT_ARM_MSK, 1) |
  742. AD8460_CURRENT_LIMIT_CONV(abs(tmp[0])));
  743. }
  744. ret = device_property_read_u32_array(dev, "adi,range-microvolt",
  745. tmp, ARRAY_SIZE(tmp));
  746. if (!ret) {
  747. if (in_range(tmp[1], 0, AD8460_ABS_MAX_OVERVOLTAGE_UV))
  748. regmap_write(state->regmap, AD8460_CTRL_REG(0x0A),
  749. FIELD_PREP(AD8460_FAULT_ARM_MSK, 1) |
  750. AD8460_VOLTAGE_LIMIT_CONV(tmp[1]));
  751. if (in_range(tmp[0], -AD8460_ABS_MAX_OVERVOLTAGE_UV, 0))
  752. regmap_write(state->regmap, AD8460_CTRL_REG(0x0B),
  753. FIELD_PREP(AD8460_FAULT_ARM_MSK, 1) |
  754. AD8460_VOLTAGE_LIMIT_CONV(abs(tmp[0])));
  755. }
  756. ret = device_property_read_u32(dev, "adi,max-millicelsius", &temp);
  757. if (!ret) {
  758. if (in_range(temp, AD8460_MIN_OVERTEMPERATURE_MC,
  759. AD8460_MAX_OVERTEMPERATURE_MC))
  760. regmap_write(state->regmap, AD8460_CTRL_REG(0x0C),
  761. FIELD_PREP(AD8460_FAULT_ARM_MSK, 1) |
  762. AD8460_TEMP_LIMIT_CONV(abs(temp)));
  763. }
  764. ret = ad8460_reset(state);
  765. if (ret)
  766. return ret;
  767. /* Enables DAC by default */
  768. ret = regmap_clear_bits(state->regmap, AD8460_CTRL_REG(0x01),
  769. AD8460_HVDAC_SLEEP_MSK);
  770. if (ret)
  771. return ret;
  772. indio_dev->modes = INDIO_DIRECT_MODE;
  773. indio_dev->setup_ops = &ad8460_buffer_setup_ops;
  774. ret = devm_iio_dmaengine_buffer_setup_ext(dev, indio_dev, "tx",
  775. IIO_BUFFER_DIRECTION_OUT);
  776. if (ret)
  777. return dev_err_probe(dev, ret,
  778. "Failed to get DMA buffer\n");
  779. return devm_iio_device_register(dev, indio_dev);
  780. }
  781. static const struct of_device_id ad8460_of_match[] = {
  782. { .compatible = "adi,ad8460" },
  783. { }
  784. };
  785. MODULE_DEVICE_TABLE(of, ad8460_of_match);
  786. static const struct spi_device_id ad8460_spi_match[] = {
  787. { .name = "ad8460" },
  788. { }
  789. };
  790. MODULE_DEVICE_TABLE(spi, ad8460_spi_match);
  791. static struct spi_driver ad8460_driver = {
  792. .driver = {
  793. .name = "ad8460",
  794. .of_match_table = ad8460_of_match,
  795. },
  796. .probe = ad8460_probe,
  797. .id_table = ad8460_spi_match,
  798. };
  799. module_spi_driver(ad8460_driver);
  800. MODULE_AUTHOR("Mariel Tinaco <mariel.tinaco@analog.com");
  801. MODULE_DESCRIPTION("AD8460 DAC driver");
  802. MODULE_LICENSE("GPL");
  803. MODULE_IMPORT_NS("IIO_DMAENGINE_BUFFER");