ada4250.c 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * ADA4250 driver
  4. *
  5. * Copyright 2022 Analog Devices Inc.
  6. */
  7. #include <linux/bitfield.h>
  8. #include <linux/bits.h>
  9. #include <linux/device.h>
  10. #include <linux/iio/iio.h>
  11. #include <linux/module.h>
  12. #include <linux/regmap.h>
  13. #include <linux/regulator/consumer.h>
  14. #include <linux/spi/spi.h>
  15. #include <linux/types.h>
  16. #include <linux/units.h>
  17. /* ADA4250 Register Map */
  18. #define ADA4250_REG_GAIN_MUX 0x00
  19. #define ADA4250_REG_REFBUF_EN 0x01
  20. #define ADA4250_REG_RESET 0x02
  21. #define ADA4250_REG_SNSR_CAL_VAL 0x04
  22. #define ADA4250_REG_SNSR_CAL_CNFG 0x05
  23. #define ADA4250_REG_DIE_REV 0x18
  24. #define ADA4250_REG_CHIP_ID 0x19
  25. /* ADA4250_REG_GAIN_MUX Map */
  26. #define ADA4250_GAIN_MUX_MSK GENMASK(2, 0)
  27. /* ADA4250_REG_REFBUF Map */
  28. #define ADA4250_REFBUF_MSK BIT(0)
  29. /* ADA4250_REG_RESET Map */
  30. #define ADA4250_RESET_MSK BIT(0)
  31. /* ADA4250_REG_SNSR_CAL_VAL Map */
  32. #define ADA4250_CAL_CFG_BIAS_MSK GENMASK(7, 0)
  33. /* ADA4250_REG_SNSR_CAL_CNFG Bit Definition */
  34. #define ADA4250_BIAS_SET_MSK GENMASK(3, 2)
  35. #define ADA4250_RANGE_SET_MSK GENMASK(1, 0)
  36. /* Miscellaneous definitions */
  37. #define ADA4250_CHIP_ID 0x4250
  38. #define ADA4250_RANGE1 0
  39. #define ADA4250_RANGE4 3
  40. /* ADA4250 current bias set */
  41. enum ada4250_current_bias {
  42. ADA4250_BIAS_DISABLED,
  43. ADA4250_BIAS_BANDGAP,
  44. ADA4250_BIAS_AVDD,
  45. };
  46. struct ada4250_state {
  47. struct spi_device *spi;
  48. struct regmap *regmap;
  49. /* Protect against concurrent accesses to the device and data content */
  50. struct mutex lock;
  51. int avdd_uv;
  52. int offset_uv;
  53. u8 bias;
  54. u8 gain;
  55. bool refbuf_en;
  56. __le16 reg_val_16 __aligned(IIO_DMA_MINALIGN);
  57. };
  58. /* ADA4250 Current Bias Source Settings: Disabled, Bandgap Reference, AVDD */
  59. static const int calibbias_table[] = {0, 1, 2};
  60. /* ADA4250 Gain (V/V) values: 1, 2, 4, 8, 16, 32, 64, 128 */
  61. static const int hwgain_table[] = {1, 2, 4, 8, 16, 32, 64, 128};
  62. static const struct regmap_config ada4250_regmap_config = {
  63. .reg_bits = 8,
  64. .val_bits = 8,
  65. .read_flag_mask = BIT(7),
  66. .max_register = 0x1A,
  67. };
  68. static int ada4250_set_offset_uv(struct iio_dev *indio_dev,
  69. const struct iio_chan_spec *chan,
  70. int offset_uv)
  71. {
  72. struct ada4250_state *st = iio_priv(indio_dev);
  73. int i, ret, x[8], max_vos, min_vos, voltage_v, vlsb = 0;
  74. u8 offset_raw, range = ADA4250_RANGE1;
  75. u32 lsb_coeff[6] = {1333, 2301, 4283, 8289, 16311, 31599};
  76. if (st->bias == 0 || st->bias == 3)
  77. return -EINVAL;
  78. voltage_v = DIV_ROUND_CLOSEST(st->avdd_uv, MICRO);
  79. if (st->bias == ADA4250_BIAS_AVDD)
  80. x[0] = voltage_v;
  81. else
  82. x[0] = 5;
  83. x[1] = 126 * (x[0] - 1);
  84. for (i = 0; i < 6; i++)
  85. x[i + 2] = DIV_ROUND_CLOSEST(x[1] * 1000, lsb_coeff[i]);
  86. if (st->gain == 0)
  87. return -EINVAL;
  88. /*
  89. * Compute Range and Voltage per LSB for the Sensor Offset Calibration
  90. * Example of computation for Range 1 and Range 2 (Curren Bias Set = AVDD):
  91. * Range 1 Range 2
  92. * Gain | Max Vos(mV) | LSB(mV) | Max Vos(mV) | LSB(mV) |
  93. * 2 | X1*127 | X1=0.126(AVDD-1) | X1*3*127 | X1*3 |
  94. * 4 | X2*127 | X2=X1/1.3333 | X2*3*127 | X2*3 |
  95. * 8 | X3*127 | X3=X1/2.301 | X3*3*127 | X3*3 |
  96. * 16 | X4*127 | X4=X1/4.283 | X4*3*127 | X4*3 |
  97. * 32 | X5*127 | X5=X1/8.289 | X5*3*127 | X5*3 |
  98. * 64 | X6*127 | X6=X1/16.311 | X6*3*127 | X6*3 |
  99. * 128 | X7*127 | X7=X1/31.599 | X7*3*127 | X7*3 |
  100. */
  101. for (i = ADA4250_RANGE1; i <= ADA4250_RANGE4; i++) {
  102. max_vos = x[st->gain] * 127 * ((1 << (i + 1)) - 1);
  103. min_vos = -1 * max_vos;
  104. if (offset_uv > min_vos && offset_uv < max_vos) {
  105. range = i;
  106. vlsb = x[st->gain] * ((1 << (i + 1)) - 1);
  107. break;
  108. }
  109. }
  110. if (vlsb <= 0)
  111. return -EINVAL;
  112. offset_raw = DIV_ROUND_CLOSEST(abs(offset_uv), vlsb);
  113. mutex_lock(&st->lock);
  114. ret = regmap_update_bits(st->regmap, ADA4250_REG_SNSR_CAL_CNFG,
  115. ADA4250_RANGE_SET_MSK,
  116. FIELD_PREP(ADA4250_RANGE_SET_MSK, range));
  117. if (ret)
  118. goto exit;
  119. st->offset_uv = offset_raw * vlsb;
  120. /*
  121. * To set the offset calibration value, use bits [6:0] and bit 7 as the
  122. * polarity bit (set to "0" for a negative offset and "1" for a positive
  123. * offset).
  124. */
  125. if (offset_uv < 0) {
  126. offset_raw |= BIT(7);
  127. st->offset_uv *= (-1);
  128. }
  129. ret = regmap_write(st->regmap, ADA4250_REG_SNSR_CAL_VAL, offset_raw);
  130. exit:
  131. mutex_unlock(&st->lock);
  132. return ret;
  133. }
  134. static int ada4250_read_raw(struct iio_dev *indio_dev,
  135. struct iio_chan_spec const *chan,
  136. int *val, int *val2, long info)
  137. {
  138. struct ada4250_state *st = iio_priv(indio_dev);
  139. int ret;
  140. switch (info) {
  141. case IIO_CHAN_INFO_HARDWAREGAIN:
  142. ret = regmap_read(st->regmap, ADA4250_REG_GAIN_MUX, val);
  143. if (ret)
  144. return ret;
  145. *val = BIT(*val);
  146. return IIO_VAL_INT;
  147. case IIO_CHAN_INFO_OFFSET:
  148. *val = st->offset_uv;
  149. return IIO_VAL_INT;
  150. case IIO_CHAN_INFO_CALIBBIAS:
  151. ret = regmap_read(st->regmap, ADA4250_REG_SNSR_CAL_CNFG, val);
  152. if (ret)
  153. return ret;
  154. *val = FIELD_GET(ADA4250_BIAS_SET_MSK, *val);
  155. return IIO_VAL_INT;
  156. case IIO_CHAN_INFO_SCALE:
  157. *val = 1;
  158. *val2 = 1000000;
  159. return IIO_VAL_FRACTIONAL;
  160. default:
  161. return -EINVAL;
  162. }
  163. }
  164. static int ada4250_write_raw(struct iio_dev *indio_dev,
  165. struct iio_chan_spec const *chan,
  166. int val, int val2, long info)
  167. {
  168. struct ada4250_state *st = iio_priv(indio_dev);
  169. int ret;
  170. switch (info) {
  171. case IIO_CHAN_INFO_HARDWAREGAIN:
  172. ret = regmap_write(st->regmap, ADA4250_REG_GAIN_MUX,
  173. FIELD_PREP(ADA4250_GAIN_MUX_MSK, ilog2(val)));
  174. if (ret)
  175. return ret;
  176. st->gain = ilog2(val);
  177. return ret;
  178. case IIO_CHAN_INFO_OFFSET:
  179. return ada4250_set_offset_uv(indio_dev, chan, val);
  180. case IIO_CHAN_INFO_CALIBBIAS:
  181. ret = regmap_update_bits(st->regmap, ADA4250_REG_SNSR_CAL_CNFG,
  182. ADA4250_BIAS_SET_MSK,
  183. FIELD_PREP(ADA4250_BIAS_SET_MSK, val));
  184. if (ret)
  185. return ret;
  186. st->bias = val;
  187. return ret;
  188. default:
  189. return -EINVAL;
  190. }
  191. }
  192. static int ada4250_read_avail(struct iio_dev *indio_dev,
  193. struct iio_chan_spec const *chan,
  194. const int **vals, int *type, int *length,
  195. long mask)
  196. {
  197. switch (mask) {
  198. case IIO_CHAN_INFO_CALIBBIAS:
  199. *vals = calibbias_table;
  200. *type = IIO_VAL_INT;
  201. *length = ARRAY_SIZE(calibbias_table);
  202. return IIO_AVAIL_LIST;
  203. case IIO_CHAN_INFO_HARDWAREGAIN:
  204. *vals = hwgain_table;
  205. *type = IIO_VAL_INT;
  206. *length = ARRAY_SIZE(hwgain_table);
  207. return IIO_AVAIL_LIST;
  208. default:
  209. return -EINVAL;
  210. }
  211. }
  212. static int ada4250_reg_access(struct iio_dev *indio_dev,
  213. unsigned int reg,
  214. unsigned int write_val,
  215. unsigned int *read_val)
  216. {
  217. struct ada4250_state *st = iio_priv(indio_dev);
  218. if (read_val)
  219. return regmap_read(st->regmap, reg, read_val);
  220. else
  221. return regmap_write(st->regmap, reg, write_val);
  222. }
  223. static const struct iio_info ada4250_info = {
  224. .read_raw = ada4250_read_raw,
  225. .write_raw = ada4250_write_raw,
  226. .read_avail = &ada4250_read_avail,
  227. .debugfs_reg_access = &ada4250_reg_access,
  228. };
  229. static const struct iio_chan_spec ada4250_channels[] = {
  230. {
  231. .type = IIO_VOLTAGE,
  232. .output = 1,
  233. .indexed = 1,
  234. .channel = 0,
  235. .info_mask_separate = BIT(IIO_CHAN_INFO_HARDWAREGAIN) |
  236. BIT(IIO_CHAN_INFO_OFFSET) |
  237. BIT(IIO_CHAN_INFO_CALIBBIAS) |
  238. BIT(IIO_CHAN_INFO_SCALE),
  239. .info_mask_separate_available = BIT(IIO_CHAN_INFO_CALIBBIAS) |
  240. BIT(IIO_CHAN_INFO_HARDWAREGAIN),
  241. }
  242. };
  243. static int ada4250_init(struct ada4250_state *st)
  244. {
  245. struct device *dev = &st->spi->dev;
  246. int ret;
  247. u16 chip_id;
  248. st->refbuf_en = device_property_read_bool(dev, "adi,refbuf-enable");
  249. st->avdd_uv = devm_regulator_get_enable_read_voltage(dev, "avdd");
  250. if (st->avdd_uv < 0)
  251. return dev_err_probe(dev, st->avdd_uv,
  252. "failed to get the AVDD voltage\n");
  253. ret = regmap_write(st->regmap, ADA4250_REG_RESET,
  254. FIELD_PREP(ADA4250_RESET_MSK, 1));
  255. if (ret)
  256. return ret;
  257. ret = regmap_bulk_read(st->regmap, ADA4250_REG_CHIP_ID, &st->reg_val_16,
  258. sizeof(st->reg_val_16));
  259. if (ret)
  260. return ret;
  261. chip_id = le16_to_cpu(st->reg_val_16);
  262. if (chip_id != ADA4250_CHIP_ID)
  263. dev_info(dev, "Invalid chip ID: 0x%02X.\n", chip_id);
  264. return regmap_write(st->regmap, ADA4250_REG_REFBUF_EN,
  265. FIELD_PREP(ADA4250_REFBUF_MSK, st->refbuf_en));
  266. }
  267. static int ada4250_probe(struct spi_device *spi)
  268. {
  269. struct iio_dev *indio_dev;
  270. struct regmap *regmap;
  271. struct ada4250_state *st;
  272. int ret;
  273. indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st));
  274. if (!indio_dev)
  275. return -ENOMEM;
  276. regmap = devm_regmap_init_spi(spi, &ada4250_regmap_config);
  277. if (IS_ERR(regmap))
  278. return PTR_ERR(regmap);
  279. st = iio_priv(indio_dev);
  280. st->regmap = regmap;
  281. st->spi = spi;
  282. indio_dev->info = &ada4250_info;
  283. indio_dev->name = "ada4250";
  284. indio_dev->channels = ada4250_channels;
  285. indio_dev->num_channels = ARRAY_SIZE(ada4250_channels);
  286. mutex_init(&st->lock);
  287. ret = ada4250_init(st);
  288. if (ret)
  289. return dev_err_probe(&spi->dev, ret, "ADA4250 init failed\n");
  290. return devm_iio_device_register(&spi->dev, indio_dev);
  291. }
  292. static const struct spi_device_id ada4250_id[] = {
  293. { "ada4250", 0 },
  294. { }
  295. };
  296. MODULE_DEVICE_TABLE(spi, ada4250_id);
  297. static const struct of_device_id ada4250_of_match[] = {
  298. { .compatible = "adi,ada4250" },
  299. { }
  300. };
  301. MODULE_DEVICE_TABLE(of, ada4250_of_match);
  302. static struct spi_driver ada4250_driver = {
  303. .driver = {
  304. .name = "ada4250",
  305. .of_match_table = ada4250_of_match,
  306. },
  307. .probe = ada4250_probe,
  308. .id_table = ada4250_id,
  309. };
  310. module_spi_driver(ada4250_driver);
  311. MODULE_AUTHOR("Antoniu Miclaus <antoniu.miclaus@analog.com");
  312. MODULE_DESCRIPTION("Analog Devices ADA4250");
  313. MODULE_LICENSE("GPL v2");