Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

iio: adc: max14001: New driver

The MAX14001/MAX14002 is configurable, isolated 10-bit ADCs for multi-range
binary inputs. In addition to ADC readings, the MAX14001/MAX14002 offers
more features, like a binary comparator, a filtered reading that can
provide the average of the last 2, 4, or 8 ADC readings, and an inrush
comparator that triggers the inrush current. There is also a fault feature
that can diagnose seven possible fault conditions. And an option to select
an external or internal ADC voltage reference.

MAX14001/MAX14002 features implemented so far:
- Raw ADC reading.
- MV fault disable.
- Selection of external or internal ADC voltage reference, depending on
whether it is declared in the device tree.

Co-developed-by: Kim Seer Paller <kimseer.paller@analog.com>
Signed-off-by: Kim Seer Paller <kimseer.paller@analog.com>
Signed-off-by: Marilene Andrade Garcia <marilene.agarcia@gmail.com>
Tested-by: Marcelo Schmitt <marcelo.schmitt1@gmail.com>
Reviewed-by: Marcelo Schmitt <marcelo.schmitt1@gmail.com>
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>

authored by

Marilene Andrade Garcia and committed by
Jonathan Cameron
59795109 192e5bbf

+403
+1
MAINTAINERS
··· 15181 15181 S: Maintained 15182 15182 W: https://ez.analog.com/linux-software-drivers 15183 15183 F: Documentation/devicetree/bindings/iio/adc/adi,max14001.yaml 15184 + F: drivers/iio/adc/max14001.c 15184 15185 15185 15186 MAX15301 DRIVER 15186 15187 M: Daniel Nilsson <daniel.nilsson@flex.com>
+10
drivers/iio/adc/Kconfig
··· 1020 1020 To compile this driver as a module, choose M here: the module will be 1021 1021 called max1363. 1022 1022 1023 + config MAX14001 1024 + tristate "Analog Devices MAX14001/MAX14002 ADC driver" 1025 + depends on SPI 1026 + help 1027 + Say yes here to build support for Analog Devices MAX14001/MAX14002 1028 + Configurable, Isolated 10-bit ADCs for Multi-Range Binary Inputs. 1029 + 1030 + To compile this driver as a module, choose M here: the module will be 1031 + called max14001. 1032 + 1023 1033 config MAX34408 1024 1034 tristate "Maxim max34408/max344089 ADC driver" 1025 1035 depends on I2C
+1
drivers/iio/adc/Makefile
··· 89 89 obj-$(CONFIG_MAX11410) += max11410.o 90 90 obj-$(CONFIG_MAX1241) += max1241.o 91 91 obj-$(CONFIG_MAX1363) += max1363.o 92 + obj-$(CONFIG_MAX14001) += max14001.o 92 93 obj-$(CONFIG_MAX34408) += max34408.o 93 94 obj-$(CONFIG_MAX77541_ADC) += max77541-adc.o 94 95 obj-$(CONFIG_MAX9611) += max9611.o
+391
drivers/iio/adc/max14001.c
··· 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 + 12 + #include <linux/array_size.h> 13 + #include <linux/bitfield.h> 14 + #include <linux/bitrev.h> 15 + #include <linux/bits.h> 16 + #include <linux/cleanup.h> 17 + #include <linux/device.h> 18 + #include <linux/mod_devicetable.h> 19 + #include <linux/module.h> 20 + #include <linux/regmap.h> 21 + #include <linux/regulator/consumer.h> 22 + #include <linux/spi/spi.h> 23 + #include <linux/types.h> 24 + #include <linux/units.h> 25 + #include <asm/byteorder.h> 26 + 27 + #include <linux/iio/iio.h> 28 + #include <linux/iio/types.h> 29 + 30 + /* MAX14001 Registers Address */ 31 + #define MAX14001_REG_ADC 0x00 32 + #define MAX14001_REG_FADC 0x01 33 + #define MAX14001_REG_FLAGS 0x02 34 + #define MAX14001_REG_FLTEN 0x03 35 + #define MAX14001_REG_THL 0x04 36 + #define MAX14001_REG_THU 0x05 37 + #define MAX14001_REG_INRR 0x06 38 + #define MAX14001_REG_INRT 0x07 39 + #define MAX14001_REG_INRP 0x08 40 + #define MAX14001_REG_CFG 0x09 41 + #define MAX14001_REG_ENBL 0x0A 42 + #define MAX14001_REG_ACT 0x0B 43 + #define MAX14001_REG_WEN 0x0C 44 + 45 + #define MAX14001_REG_VERIFICATION(x) ((x) + 0x10) 46 + 47 + #define MAX14001_REG_CFG_BIT_EXRF BIT(5) 48 + 49 + #define MAX14001_REG_WEN_VALUE_WRITE 0x294 50 + 51 + #define MAX14001_MASK_ADDR GENMASK(15, 11) 52 + #define MAX14001_MASK_WR BIT(10) 53 + #define MAX14001_MASK_DATA GENMASK(9, 0) 54 + 55 + struct max14001_state { 56 + const struct max14001_chip_info *chip_info; 57 + struct spi_device *spi; 58 + struct regmap *regmap; 59 + int vref_mV; 60 + bool spi_hw_has_lsb_first; 61 + 62 + /* 63 + * The following buffers will be bit-reversed during device 64 + * communication, because the device transmits and receives data 65 + * LSB-first. 66 + * DMA (thus cache coherency maintenance) requires the transfer 67 + * buffers to live in their own cache lines. 68 + */ 69 + union { 70 + __be16 be; 71 + __le16 le; 72 + } spi_tx_buffer __aligned(IIO_DMA_MINALIGN); 73 + 74 + union { 75 + __be16 be; 76 + __le16 le; 77 + } spi_rx_buffer; 78 + }; 79 + 80 + struct max14001_chip_info { 81 + const char *name; 82 + }; 83 + 84 + static int max14001_read(void *context, unsigned int reg, unsigned int *val) 85 + { 86 + struct max14001_state *st = context; 87 + struct spi_transfer xfers[] = { 88 + { 89 + .tx_buf = &st->spi_tx_buffer, 90 + .len = sizeof(st->spi_tx_buffer), 91 + .cs_change = 1, 92 + }, { 93 + .rx_buf = &st->spi_rx_buffer, 94 + .len = sizeof(st->spi_rx_buffer), 95 + }, 96 + }; 97 + int ret; 98 + unsigned int addr, data; 99 + 100 + /* 101 + * Prepare SPI transmit buffer 16 bit-value and reverse bit order 102 + * to align with the LSB-first input on SDI port in order to meet 103 + * the device communication requirements. If the controller supports 104 + * SPI_LSB_FIRST, this step will be handled by the SPI controller. 105 + */ 106 + addr = FIELD_PREP(MAX14001_MASK_ADDR, reg); 107 + 108 + if (st->spi_hw_has_lsb_first) 109 + st->spi_tx_buffer.le = cpu_to_le16(addr); 110 + else 111 + st->spi_tx_buffer.be = cpu_to_be16(bitrev16(addr)); 112 + 113 + ret = spi_sync_transfer(st->spi, xfers, ARRAY_SIZE(xfers)); 114 + if (ret) 115 + return ret; 116 + 117 + /* 118 + * Convert received 16-bit value to cpu-endian format and reverse 119 + * bit order. If the controller supports SPI_LSB_FIRST, this step 120 + * will be handled by the SPI controller. 121 + */ 122 + if (st->spi_hw_has_lsb_first) 123 + data = le16_to_cpu(st->spi_rx_buffer.le); 124 + else 125 + data = bitrev16(be16_to_cpu(st->spi_rx_buffer.be)); 126 + 127 + *val = FIELD_GET(MAX14001_MASK_DATA, data); 128 + 129 + return 0; 130 + } 131 + 132 + static int max14001_write(struct max14001_state *st, unsigned int reg, unsigned int val) 133 + { 134 + unsigned int addr; 135 + 136 + /* 137 + * Prepare SPI transmit buffer 16 bit-value and reverse bit order 138 + * to align with the LSB-first input on SDI port in order to meet 139 + * the device communication requirements. If the controller supports 140 + * SPI_LSB_FIRST, this step will be handled by the SPI controller. 141 + */ 142 + addr = FIELD_PREP(MAX14001_MASK_ADDR, reg) | 143 + FIELD_PREP(MAX14001_MASK_WR, 1) | 144 + FIELD_PREP(MAX14001_MASK_DATA, val); 145 + 146 + if (st->spi_hw_has_lsb_first) 147 + st->spi_tx_buffer.le = cpu_to_le16(addr); 148 + else 149 + st->spi_tx_buffer.be = cpu_to_be16(bitrev16(addr)); 150 + 151 + return spi_write(st->spi, &st->spi_tx_buffer, sizeof(st->spi_tx_buffer)); 152 + } 153 + 154 + static int max14001_write_single_reg(void *context, unsigned int reg, unsigned int val) 155 + { 156 + struct max14001_state *st = context; 157 + int ret; 158 + 159 + /* Enable writing to the SPI register. */ 160 + ret = max14001_write(st, MAX14001_REG_WEN, MAX14001_REG_WEN_VALUE_WRITE); 161 + if (ret) 162 + return ret; 163 + 164 + /* Writing data into SPI register. */ 165 + ret = max14001_write(st, reg, val); 166 + if (ret) 167 + return ret; 168 + 169 + /* Disable writing to the SPI register. */ 170 + return max14001_write(st, MAX14001_REG_WEN, 0); 171 + } 172 + 173 + static int max14001_write_verification_reg(struct max14001_state *st, unsigned int reg) 174 + { 175 + unsigned int val; 176 + int ret; 177 + 178 + ret = regmap_read(st->regmap, reg, &val); 179 + if (ret) 180 + return ret; 181 + 182 + return max14001_write(st, MAX14001_REG_VERIFICATION(reg), val); 183 + } 184 + 185 + static int max14001_disable_mv_fault(struct max14001_state *st) 186 + { 187 + unsigned int reg; 188 + int ret; 189 + 190 + /* Enable writing to the SPI registers. */ 191 + ret = max14001_write(st, MAX14001_REG_WEN, MAX14001_REG_WEN_VALUE_WRITE); 192 + if (ret) 193 + return ret; 194 + 195 + /* 196 + * Reads all registers and writes the values to their appropriate 197 + * verification registers to clear the Memory Validation fault. 198 + */ 199 + for (reg = MAX14001_REG_FLTEN; reg <= MAX14001_REG_ENBL; reg++) { 200 + ret = max14001_write_verification_reg(st, reg); 201 + if (ret) 202 + return ret; 203 + } 204 + 205 + /* Disable writing to the SPI registers. */ 206 + return max14001_write(st, MAX14001_REG_WEN, 0); 207 + } 208 + 209 + static int max14001_debugfs_reg_access(struct iio_dev *indio_dev, 210 + unsigned int reg, unsigned int writeval, 211 + unsigned int *readval) 212 + { 213 + struct max14001_state *st = iio_priv(indio_dev); 214 + 215 + if (readval) 216 + return regmap_read(st->regmap, reg, readval); 217 + 218 + return regmap_write(st->regmap, reg, writeval); 219 + } 220 + 221 + static int max14001_read_raw(struct iio_dev *indio_dev, 222 + struct iio_chan_spec const *chan, 223 + int *val, int *val2, long mask) 224 + { 225 + struct max14001_state *st = iio_priv(indio_dev); 226 + int ret; 227 + 228 + switch (mask) { 229 + case IIO_CHAN_INFO_RAW: 230 + ret = regmap_read(st->regmap, MAX14001_REG_ADC, val); 231 + if (ret) 232 + return ret; 233 + 234 + return IIO_VAL_INT; 235 + case IIO_CHAN_INFO_SCALE: 236 + *val = st->vref_mV; 237 + *val2 = 10; 238 + 239 + return IIO_VAL_FRACTIONAL_LOG2; 240 + default: 241 + return -EINVAL; 242 + } 243 + } 244 + 245 + static const struct regmap_range max14001_regmap_rd_range[] = { 246 + regmap_reg_range(MAX14001_REG_ADC, MAX14001_REG_ENBL), 247 + regmap_reg_range(MAX14001_REG_WEN, MAX14001_REG_WEN), 248 + regmap_reg_range(MAX14001_REG_VERIFICATION(MAX14001_REG_FLTEN), 249 + MAX14001_REG_VERIFICATION(MAX14001_REG_ENBL)), 250 + }; 251 + 252 + static const struct regmap_access_table max14001_regmap_rd_table = { 253 + .yes_ranges = max14001_regmap_rd_range, 254 + .n_yes_ranges = ARRAY_SIZE(max14001_regmap_rd_range), 255 + }; 256 + 257 + static const struct regmap_range max14001_regmap_wr_range[] = { 258 + regmap_reg_range(MAX14001_REG_FLTEN, MAX14001_REG_WEN), 259 + regmap_reg_range(MAX14001_REG_VERIFICATION(MAX14001_REG_FLTEN), 260 + MAX14001_REG_VERIFICATION(MAX14001_REG_ENBL)), 261 + }; 262 + 263 + static const struct regmap_access_table max14001_regmap_wr_table = { 264 + .yes_ranges = max14001_regmap_wr_range, 265 + .n_yes_ranges = ARRAY_SIZE(max14001_regmap_wr_range), 266 + }; 267 + 268 + static const struct regmap_config max14001_regmap_config = { 269 + .reg_read = max14001_read, 270 + .reg_write = max14001_write_single_reg, 271 + .max_register = MAX14001_REG_VERIFICATION(MAX14001_REG_ENBL), 272 + .rd_table = &max14001_regmap_rd_table, 273 + .wr_table = &max14001_regmap_wr_table, 274 + }; 275 + 276 + static const struct iio_info max14001_info = { 277 + .read_raw = max14001_read_raw, 278 + .debugfs_reg_access = max14001_debugfs_reg_access, 279 + }; 280 + 281 + static const struct iio_chan_spec max14001_channel[] = { 282 + { 283 + .type = IIO_VOLTAGE, 284 + .indexed = 1, 285 + .channel = 0, 286 + .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) | 287 + BIT(IIO_CHAN_INFO_SCALE), 288 + }, 289 + }; 290 + 291 + static int max14001_probe(struct spi_device *spi) 292 + { 293 + struct device *dev = &spi->dev; 294 + struct iio_dev *indio_dev; 295 + struct max14001_state *st; 296 + int ret; 297 + bool use_ext_vrefin = false; 298 + 299 + indio_dev = devm_iio_device_alloc(dev, sizeof(*st)); 300 + if (!indio_dev) 301 + return -ENOMEM; 302 + 303 + st = iio_priv(indio_dev); 304 + st->spi = spi; 305 + st->spi_hw_has_lsb_first = spi->mode & SPI_LSB_FIRST; 306 + st->chip_info = spi_get_device_match_data(spi); 307 + if (!st->chip_info) 308 + return -EINVAL; 309 + 310 + indio_dev->name = st->chip_info->name; 311 + indio_dev->info = &max14001_info; 312 + indio_dev->channels = max14001_channel; 313 + indio_dev->num_channels = ARRAY_SIZE(max14001_channel); 314 + indio_dev->modes = INDIO_DIRECT_MODE; 315 + 316 + st->regmap = devm_regmap_init(dev, NULL, st, &max14001_regmap_config); 317 + if (IS_ERR(st->regmap)) 318 + return dev_err_probe(dev, PTR_ERR(st->regmap), "Failed to initialize regmap\n"); 319 + 320 + ret = devm_regulator_get_enable(dev, "vdd"); 321 + if (ret) 322 + return dev_err_probe(dev, ret, "Failed to enable Vdd supply\n"); 323 + 324 + ret = devm_regulator_get_enable(dev, "vddl"); 325 + if (ret) 326 + return dev_err_probe(dev, ret, "Failed to enable Vddl supply\n"); 327 + 328 + ret = devm_regulator_get_enable_read_voltage(dev, "refin"); 329 + if (ret < 0 && ret != -ENODEV) 330 + return dev_err_probe(dev, ret, "Failed to get REFIN voltage\n"); 331 + 332 + if (ret == -ENODEV) 333 + ret = 1250000; 334 + else 335 + use_ext_vrefin = true; 336 + st->vref_mV = ret / (MICRO / MILLI); 337 + 338 + if (use_ext_vrefin) { 339 + /* 340 + * Configure the MAX14001/MAX14002 to use an external voltage 341 + * reference source by setting the bit 5 of the configuration register. 342 + */ 343 + ret = regmap_set_bits(st->regmap, MAX14001_REG_CFG, 344 + MAX14001_REG_CFG_BIT_EXRF); 345 + if (ret) 346 + return dev_err_probe(dev, ret, 347 + "Failed to set External REFIN in Configuration Register\n"); 348 + } 349 + 350 + ret = max14001_disable_mv_fault(st); 351 + if (ret) 352 + return dev_err_probe(dev, ret, "Failed to disable MV Fault\n"); 353 + 354 + return devm_iio_device_register(dev, indio_dev); 355 + } 356 + 357 + static struct max14001_chip_info max14001_chip_info = { 358 + .name = "max14001", 359 + }; 360 + 361 + static struct max14001_chip_info max14002_chip_info = { 362 + .name = "max14002", 363 + }; 364 + 365 + static const struct spi_device_id max14001_id_table[] = { 366 + { "max14001", (kernel_ulong_t)&max14001_chip_info }, 367 + { "max14002", (kernel_ulong_t)&max14002_chip_info }, 368 + { } 369 + }; 370 + 371 + static const struct of_device_id max14001_of_match[] = { 372 + { .compatible = "adi,max14001", .data = &max14001_chip_info }, 373 + { .compatible = "adi,max14002", .data = &max14002_chip_info }, 374 + { } 375 + }; 376 + MODULE_DEVICE_TABLE(of, max14001_of_match); 377 + 378 + static struct spi_driver max14001_driver = { 379 + .driver = { 380 + .name = "max14001", 381 + .of_match_table = max14001_of_match, 382 + }, 383 + .probe = max14001_probe, 384 + .id_table = max14001_id_table, 385 + }; 386 + module_spi_driver(max14001_driver); 387 + 388 + MODULE_AUTHOR("Kim Seer Paller <kimseer.paller@analog.com>"); 389 + MODULE_AUTHOR("Marilene Andrade Garcia <marilene.agarcia@gmail.com>"); 390 + MODULE_DESCRIPTION("Analog Devices MAX14001/MAX14002 ADCs driver"); 391 + MODULE_LICENSE("GPL");