max14001.c 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391
  1. // SPDX-License-Identifier: (GPL-2.0-only OR BSD-3-Clause)
  2. /*
  3. * Analog Devices MAX14001/MAX14002 ADC driver
  4. *
  5. * Copyright (C) 2023-2025 Analog Devices Inc.
  6. * Copyright (C) 2023 Kim Seer Paller <kimseer.paller@analog.com>
  7. * Copyright (c) 2025 Marilene Andrade Garcia <marilene.agarcia@gmail.com>
  8. *
  9. * Datasheet: https://www.analog.com/media/en/technical-documentation/data-sheets/MAX14001-MAX14002.pdf
  10. */
  11. #include <linux/array_size.h>
  12. #include <linux/bitfield.h>
  13. #include <linux/bitrev.h>
  14. #include <linux/bits.h>
  15. #include <linux/cleanup.h>
  16. #include <linux/device.h>
  17. #include <linux/mod_devicetable.h>
  18. #include <linux/module.h>
  19. #include <linux/regmap.h>
  20. #include <linux/regulator/consumer.h>
  21. #include <linux/spi/spi.h>
  22. #include <linux/types.h>
  23. #include <linux/units.h>
  24. #include <asm/byteorder.h>
  25. #include <linux/iio/iio.h>
  26. #include <linux/iio/types.h>
  27. /* MAX14001 Registers Address */
  28. #define MAX14001_REG_ADC 0x00
  29. #define MAX14001_REG_FADC 0x01
  30. #define MAX14001_REG_FLAGS 0x02
  31. #define MAX14001_REG_FLTEN 0x03
  32. #define MAX14001_REG_THL 0x04
  33. #define MAX14001_REG_THU 0x05
  34. #define MAX14001_REG_INRR 0x06
  35. #define MAX14001_REG_INRT 0x07
  36. #define MAX14001_REG_INRP 0x08
  37. #define MAX14001_REG_CFG 0x09
  38. #define MAX14001_REG_ENBL 0x0A
  39. #define MAX14001_REG_ACT 0x0B
  40. #define MAX14001_REG_WEN 0x0C
  41. #define MAX14001_REG_VERIFICATION(x) ((x) + 0x10)
  42. #define MAX14001_REG_CFG_BIT_EXRF BIT(5)
  43. #define MAX14001_REG_WEN_VALUE_WRITE 0x294
  44. #define MAX14001_MASK_ADDR GENMASK(15, 11)
  45. #define MAX14001_MASK_WR BIT(10)
  46. #define MAX14001_MASK_DATA GENMASK(9, 0)
  47. struct max14001_state {
  48. const struct max14001_chip_info *chip_info;
  49. struct spi_device *spi;
  50. struct regmap *regmap;
  51. int vref_mV;
  52. bool spi_hw_has_lsb_first;
  53. /*
  54. * The following buffers will be bit-reversed during device
  55. * communication, because the device transmits and receives data
  56. * LSB-first.
  57. * DMA (thus cache coherency maintenance) requires the transfer
  58. * buffers to live in their own cache lines.
  59. */
  60. union {
  61. __be16 be;
  62. __le16 le;
  63. } spi_tx_buffer __aligned(IIO_DMA_MINALIGN);
  64. union {
  65. __be16 be;
  66. __le16 le;
  67. } spi_rx_buffer;
  68. };
  69. struct max14001_chip_info {
  70. const char *name;
  71. };
  72. static int max14001_read(void *context, unsigned int reg, unsigned int *val)
  73. {
  74. struct max14001_state *st = context;
  75. struct spi_transfer xfers[] = {
  76. {
  77. .tx_buf = &st->spi_tx_buffer,
  78. .len = sizeof(st->spi_tx_buffer),
  79. .cs_change = 1,
  80. }, {
  81. .rx_buf = &st->spi_rx_buffer,
  82. .len = sizeof(st->spi_rx_buffer),
  83. },
  84. };
  85. int ret;
  86. unsigned int addr, data;
  87. /*
  88. * Prepare SPI transmit buffer 16 bit-value and reverse bit order
  89. * to align with the LSB-first input on SDI port in order to meet
  90. * the device communication requirements. If the controller supports
  91. * SPI_LSB_FIRST, this step will be handled by the SPI controller.
  92. */
  93. addr = FIELD_PREP(MAX14001_MASK_ADDR, reg);
  94. if (st->spi_hw_has_lsb_first)
  95. st->spi_tx_buffer.le = cpu_to_le16(addr);
  96. else
  97. st->spi_tx_buffer.be = cpu_to_be16(bitrev16(addr));
  98. ret = spi_sync_transfer(st->spi, xfers, ARRAY_SIZE(xfers));
  99. if (ret)
  100. return ret;
  101. /*
  102. * Convert received 16-bit value to cpu-endian format and reverse
  103. * bit order. If the controller supports SPI_LSB_FIRST, this step
  104. * will be handled by the SPI controller.
  105. */
  106. if (st->spi_hw_has_lsb_first)
  107. data = le16_to_cpu(st->spi_rx_buffer.le);
  108. else
  109. data = bitrev16(be16_to_cpu(st->spi_rx_buffer.be));
  110. *val = FIELD_GET(MAX14001_MASK_DATA, data);
  111. return 0;
  112. }
  113. static int max14001_write(struct max14001_state *st, unsigned int reg, unsigned int val)
  114. {
  115. unsigned int addr;
  116. /*
  117. * Prepare SPI transmit buffer 16 bit-value and reverse bit order
  118. * to align with the LSB-first input on SDI port in order to meet
  119. * the device communication requirements. If the controller supports
  120. * SPI_LSB_FIRST, this step will be handled by the SPI controller.
  121. */
  122. addr = FIELD_PREP(MAX14001_MASK_ADDR, reg) |
  123. FIELD_PREP(MAX14001_MASK_WR, 1) |
  124. FIELD_PREP(MAX14001_MASK_DATA, val);
  125. if (st->spi_hw_has_lsb_first)
  126. st->spi_tx_buffer.le = cpu_to_le16(addr);
  127. else
  128. st->spi_tx_buffer.be = cpu_to_be16(bitrev16(addr));
  129. return spi_write(st->spi, &st->spi_tx_buffer, sizeof(st->spi_tx_buffer));
  130. }
  131. static int max14001_write_single_reg(void *context, unsigned int reg, unsigned int val)
  132. {
  133. struct max14001_state *st = context;
  134. int ret;
  135. /* Enable writing to the SPI register. */
  136. ret = max14001_write(st, MAX14001_REG_WEN, MAX14001_REG_WEN_VALUE_WRITE);
  137. if (ret)
  138. return ret;
  139. /* Writing data into SPI register. */
  140. ret = max14001_write(st, reg, val);
  141. if (ret)
  142. return ret;
  143. /* Disable writing to the SPI register. */
  144. return max14001_write(st, MAX14001_REG_WEN, 0);
  145. }
  146. static int max14001_write_verification_reg(struct max14001_state *st, unsigned int reg)
  147. {
  148. unsigned int val;
  149. int ret;
  150. ret = regmap_read(st->regmap, reg, &val);
  151. if (ret)
  152. return ret;
  153. return max14001_write(st, MAX14001_REG_VERIFICATION(reg), val);
  154. }
  155. static int max14001_disable_mv_fault(struct max14001_state *st)
  156. {
  157. unsigned int reg;
  158. int ret;
  159. /* Enable writing to the SPI registers. */
  160. ret = max14001_write(st, MAX14001_REG_WEN, MAX14001_REG_WEN_VALUE_WRITE);
  161. if (ret)
  162. return ret;
  163. /*
  164. * Reads all registers and writes the values to their appropriate
  165. * verification registers to clear the Memory Validation fault.
  166. */
  167. for (reg = MAX14001_REG_FLTEN; reg <= MAX14001_REG_ENBL; reg++) {
  168. ret = max14001_write_verification_reg(st, reg);
  169. if (ret)
  170. return ret;
  171. }
  172. /* Disable writing to the SPI registers. */
  173. return max14001_write(st, MAX14001_REG_WEN, 0);
  174. }
  175. static int max14001_debugfs_reg_access(struct iio_dev *indio_dev,
  176. unsigned int reg, unsigned int writeval,
  177. unsigned int *readval)
  178. {
  179. struct max14001_state *st = iio_priv(indio_dev);
  180. if (readval)
  181. return regmap_read(st->regmap, reg, readval);
  182. return regmap_write(st->regmap, reg, writeval);
  183. }
  184. static int max14001_read_raw(struct iio_dev *indio_dev,
  185. struct iio_chan_spec const *chan,
  186. int *val, int *val2, long mask)
  187. {
  188. struct max14001_state *st = iio_priv(indio_dev);
  189. int ret;
  190. switch (mask) {
  191. case IIO_CHAN_INFO_RAW:
  192. ret = regmap_read(st->regmap, MAX14001_REG_ADC, val);
  193. if (ret)
  194. return ret;
  195. return IIO_VAL_INT;
  196. case IIO_CHAN_INFO_SCALE:
  197. *val = st->vref_mV;
  198. *val2 = 10;
  199. return IIO_VAL_FRACTIONAL_LOG2;
  200. default:
  201. return -EINVAL;
  202. }
  203. }
  204. static const struct regmap_range max14001_regmap_rd_range[] = {
  205. regmap_reg_range(MAX14001_REG_ADC, MAX14001_REG_ENBL),
  206. regmap_reg_range(MAX14001_REG_WEN, MAX14001_REG_WEN),
  207. regmap_reg_range(MAX14001_REG_VERIFICATION(MAX14001_REG_FLTEN),
  208. MAX14001_REG_VERIFICATION(MAX14001_REG_ENBL)),
  209. };
  210. static const struct regmap_access_table max14001_regmap_rd_table = {
  211. .yes_ranges = max14001_regmap_rd_range,
  212. .n_yes_ranges = ARRAY_SIZE(max14001_regmap_rd_range),
  213. };
  214. static const struct regmap_range max14001_regmap_wr_range[] = {
  215. regmap_reg_range(MAX14001_REG_FLTEN, MAX14001_REG_WEN),
  216. regmap_reg_range(MAX14001_REG_VERIFICATION(MAX14001_REG_FLTEN),
  217. MAX14001_REG_VERIFICATION(MAX14001_REG_ENBL)),
  218. };
  219. static const struct regmap_access_table max14001_regmap_wr_table = {
  220. .yes_ranges = max14001_regmap_wr_range,
  221. .n_yes_ranges = ARRAY_SIZE(max14001_regmap_wr_range),
  222. };
  223. static const struct regmap_config max14001_regmap_config = {
  224. .reg_read = max14001_read,
  225. .reg_write = max14001_write_single_reg,
  226. .max_register = MAX14001_REG_VERIFICATION(MAX14001_REG_ENBL),
  227. .rd_table = &max14001_regmap_rd_table,
  228. .wr_table = &max14001_regmap_wr_table,
  229. };
  230. static const struct iio_info max14001_info = {
  231. .read_raw = max14001_read_raw,
  232. .debugfs_reg_access = max14001_debugfs_reg_access,
  233. };
  234. static const struct iio_chan_spec max14001_channel[] = {
  235. {
  236. .type = IIO_VOLTAGE,
  237. .indexed = 1,
  238. .channel = 0,
  239. .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) |
  240. BIT(IIO_CHAN_INFO_SCALE),
  241. },
  242. };
  243. static int max14001_probe(struct spi_device *spi)
  244. {
  245. struct device *dev = &spi->dev;
  246. struct iio_dev *indio_dev;
  247. struct max14001_state *st;
  248. int ret;
  249. bool use_ext_vrefin = false;
  250. indio_dev = devm_iio_device_alloc(dev, sizeof(*st));
  251. if (!indio_dev)
  252. return -ENOMEM;
  253. st = iio_priv(indio_dev);
  254. st->spi = spi;
  255. st->spi_hw_has_lsb_first = spi->mode & SPI_LSB_FIRST;
  256. st->chip_info = spi_get_device_match_data(spi);
  257. if (!st->chip_info)
  258. return -EINVAL;
  259. indio_dev->name = st->chip_info->name;
  260. indio_dev->info = &max14001_info;
  261. indio_dev->channels = max14001_channel;
  262. indio_dev->num_channels = ARRAY_SIZE(max14001_channel);
  263. indio_dev->modes = INDIO_DIRECT_MODE;
  264. st->regmap = devm_regmap_init(dev, NULL, st, &max14001_regmap_config);
  265. if (IS_ERR(st->regmap))
  266. return dev_err_probe(dev, PTR_ERR(st->regmap), "Failed to initialize regmap\n");
  267. ret = devm_regulator_get_enable(dev, "vdd");
  268. if (ret)
  269. return dev_err_probe(dev, ret, "Failed to enable Vdd supply\n");
  270. ret = devm_regulator_get_enable(dev, "vddl");
  271. if (ret)
  272. return dev_err_probe(dev, ret, "Failed to enable Vddl supply\n");
  273. ret = devm_regulator_get_enable_read_voltage(dev, "refin");
  274. if (ret < 0 && ret != -ENODEV)
  275. return dev_err_probe(dev, ret, "Failed to get REFIN voltage\n");
  276. if (ret == -ENODEV)
  277. ret = 1250000;
  278. else
  279. use_ext_vrefin = true;
  280. st->vref_mV = ret / (MICRO / MILLI);
  281. if (use_ext_vrefin) {
  282. /*
  283. * Configure the MAX14001/MAX14002 to use an external voltage
  284. * reference source by setting the bit 5 of the configuration register.
  285. */
  286. ret = regmap_set_bits(st->regmap, MAX14001_REG_CFG,
  287. MAX14001_REG_CFG_BIT_EXRF);
  288. if (ret)
  289. return dev_err_probe(dev, ret,
  290. "Failed to set External REFIN in Configuration Register\n");
  291. }
  292. ret = max14001_disable_mv_fault(st);
  293. if (ret)
  294. return dev_err_probe(dev, ret, "Failed to disable MV Fault\n");
  295. return devm_iio_device_register(dev, indio_dev);
  296. }
  297. static struct max14001_chip_info max14001_chip_info = {
  298. .name = "max14001",
  299. };
  300. static struct max14001_chip_info max14002_chip_info = {
  301. .name = "max14002",
  302. };
  303. static const struct spi_device_id max14001_id_table[] = {
  304. { "max14001", (kernel_ulong_t)&max14001_chip_info },
  305. { "max14002", (kernel_ulong_t)&max14002_chip_info },
  306. { }
  307. };
  308. static const struct of_device_id max14001_of_match[] = {
  309. { .compatible = "adi,max14001", .data = &max14001_chip_info },
  310. { .compatible = "adi,max14002", .data = &max14002_chip_info },
  311. { }
  312. };
  313. MODULE_DEVICE_TABLE(of, max14001_of_match);
  314. static struct spi_driver max14001_driver = {
  315. .driver = {
  316. .name = "max14001",
  317. .of_match_table = max14001_of_match,
  318. },
  319. .probe = max14001_probe,
  320. .id_table = max14001_id_table,
  321. };
  322. module_spi_driver(max14001_driver);
  323. MODULE_AUTHOR("Kim Seer Paller <kimseer.paller@analog.com>");
  324. MODULE_AUTHOR("Marilene Andrade Garcia <marilene.agarcia@gmail.com>");
  325. MODULE_DESCRIPTION("Analog Devices MAX14001/MAX14002 ADCs driver");
  326. MODULE_LICENSE("GPL");