1*2e3ae10cSAlisa-Dariana Roman // SPDX-License-Identifier: GPL-2.0-only 2*2e3ae10cSAlisa-Dariana Roman /* 3*2e3ae10cSAlisa-Dariana Roman * AD7191 ADC driver 4*2e3ae10cSAlisa-Dariana Roman * 5*2e3ae10cSAlisa-Dariana Roman * Copyright 2025 Analog Devices Inc. 6*2e3ae10cSAlisa-Dariana Roman */ 7*2e3ae10cSAlisa-Dariana Roman 8*2e3ae10cSAlisa-Dariana Roman #include <linux/bitfield.h> 9*2e3ae10cSAlisa-Dariana Roman #include <linux/clk.h> 10*2e3ae10cSAlisa-Dariana Roman #include <linux/device.h> 11*2e3ae10cSAlisa-Dariana Roman #include <linux/err.h> 12*2e3ae10cSAlisa-Dariana Roman #include <linux/gpio/consumer.h> 13*2e3ae10cSAlisa-Dariana Roman #include <linux/interrupt.h> 14*2e3ae10cSAlisa-Dariana Roman #include <linux/mod_devicetable.h> 15*2e3ae10cSAlisa-Dariana Roman #include <linux/mutex.h> 16*2e3ae10cSAlisa-Dariana Roman #include <linux/property.h> 17*2e3ae10cSAlisa-Dariana Roman #include <linux/regulator/consumer.h> 18*2e3ae10cSAlisa-Dariana Roman #include <linux/spi/spi.h> 19*2e3ae10cSAlisa-Dariana Roman #include <linux/types.h> 20*2e3ae10cSAlisa-Dariana Roman #include <linux/units.h> 21*2e3ae10cSAlisa-Dariana Roman 22*2e3ae10cSAlisa-Dariana Roman #include <linux/iio/adc/ad_sigma_delta.h> 23*2e3ae10cSAlisa-Dariana Roman #include <linux/iio/iio.h> 24*2e3ae10cSAlisa-Dariana Roman 25*2e3ae10cSAlisa-Dariana Roman #define ad_sigma_delta_to_ad7191(sigmad) \ 26*2e3ae10cSAlisa-Dariana Roman container_of((sigmad), struct ad7191_state, sd) 27*2e3ae10cSAlisa-Dariana Roman 28*2e3ae10cSAlisa-Dariana Roman #define AD7191_TEMP_CODES_PER_DEGREE 2815 29*2e3ae10cSAlisa-Dariana Roman 30*2e3ae10cSAlisa-Dariana Roman #define AD7191_CHAN_MASK BIT(0) 31*2e3ae10cSAlisa-Dariana Roman #define AD7191_TEMP_MASK BIT(1) 32*2e3ae10cSAlisa-Dariana Roman 33*2e3ae10cSAlisa-Dariana Roman enum ad7191_channel { 34*2e3ae10cSAlisa-Dariana Roman AD7191_CH_AIN1_AIN2, 35*2e3ae10cSAlisa-Dariana Roman AD7191_CH_AIN3_AIN4, 36*2e3ae10cSAlisa-Dariana Roman AD7191_CH_TEMP, 37*2e3ae10cSAlisa-Dariana Roman }; 38*2e3ae10cSAlisa-Dariana Roman 39*2e3ae10cSAlisa-Dariana Roman /* 40*2e3ae10cSAlisa-Dariana Roman * NOTE: 41*2e3ae10cSAlisa-Dariana Roman * The AD7191 features a dual-use data out ready DOUT/RDY output. 42*2e3ae10cSAlisa-Dariana Roman * In order to avoid contentions on the SPI bus, it's therefore necessary 43*2e3ae10cSAlisa-Dariana Roman * to use SPI bus locking. 44*2e3ae10cSAlisa-Dariana Roman * 45*2e3ae10cSAlisa-Dariana Roman * The DOUT/RDY output must also be wired to an interrupt-capable GPIO. 46*2e3ae10cSAlisa-Dariana Roman * 47*2e3ae10cSAlisa-Dariana Roman * The SPI controller's chip select must be connected to the PDOWN pin 48*2e3ae10cSAlisa-Dariana Roman * of the ADC. When CS (PDOWN) is high, it powers down the device and 49*2e3ae10cSAlisa-Dariana Roman * resets the internal circuitry. 50*2e3ae10cSAlisa-Dariana Roman */ 51*2e3ae10cSAlisa-Dariana Roman 52*2e3ae10cSAlisa-Dariana Roman struct ad7191_state { 53*2e3ae10cSAlisa-Dariana Roman struct ad_sigma_delta sd; 54*2e3ae10cSAlisa-Dariana Roman struct mutex lock; /* Protect device state */ 55*2e3ae10cSAlisa-Dariana Roman 56*2e3ae10cSAlisa-Dariana Roman struct gpio_descs *odr_gpios; 57*2e3ae10cSAlisa-Dariana Roman struct gpio_descs *pga_gpios; 58*2e3ae10cSAlisa-Dariana Roman struct gpio_desc *temp_gpio; 59*2e3ae10cSAlisa-Dariana Roman struct gpio_desc *chan_gpio; 60*2e3ae10cSAlisa-Dariana Roman 61*2e3ae10cSAlisa-Dariana Roman u16 int_vref_mv; 62*2e3ae10cSAlisa-Dariana Roman const u32 (*scale_avail)[2]; 63*2e3ae10cSAlisa-Dariana Roman size_t scale_avail_size; 64*2e3ae10cSAlisa-Dariana Roman u32 scale_index; 65*2e3ae10cSAlisa-Dariana Roman const u32 *samp_freq_avail; 66*2e3ae10cSAlisa-Dariana Roman size_t samp_freq_avail_size; 67*2e3ae10cSAlisa-Dariana Roman u32 samp_freq_index; 68*2e3ae10cSAlisa-Dariana Roman 69*2e3ae10cSAlisa-Dariana Roman struct clk *mclk; 70*2e3ae10cSAlisa-Dariana Roman }; 71*2e3ae10cSAlisa-Dariana Roman 72*2e3ae10cSAlisa-Dariana Roman static int ad7191_set_channel(struct ad_sigma_delta *sd, unsigned int address) 73*2e3ae10cSAlisa-Dariana Roman { 74*2e3ae10cSAlisa-Dariana Roman struct ad7191_state *st = ad_sigma_delta_to_ad7191(sd); 75*2e3ae10cSAlisa-Dariana Roman u8 temp_gpio_val, chan_gpio_val; 76*2e3ae10cSAlisa-Dariana Roman 77*2e3ae10cSAlisa-Dariana Roman if (!FIELD_FIT(AD7191_CHAN_MASK | AD7191_TEMP_MASK, address)) 78*2e3ae10cSAlisa-Dariana Roman return -EINVAL; 79*2e3ae10cSAlisa-Dariana Roman 80*2e3ae10cSAlisa-Dariana Roman chan_gpio_val = FIELD_GET(AD7191_CHAN_MASK, address); 81*2e3ae10cSAlisa-Dariana Roman temp_gpio_val = FIELD_GET(AD7191_TEMP_MASK, address); 82*2e3ae10cSAlisa-Dariana Roman 83*2e3ae10cSAlisa-Dariana Roman gpiod_set_value(st->chan_gpio, chan_gpio_val); 84*2e3ae10cSAlisa-Dariana Roman gpiod_set_value(st->temp_gpio, temp_gpio_val); 85*2e3ae10cSAlisa-Dariana Roman 86*2e3ae10cSAlisa-Dariana Roman return 0; 87*2e3ae10cSAlisa-Dariana Roman } 88*2e3ae10cSAlisa-Dariana Roman 89*2e3ae10cSAlisa-Dariana Roman static int ad7191_set_cs(struct ad_sigma_delta *sigma_delta, int assert) 90*2e3ae10cSAlisa-Dariana Roman { 91*2e3ae10cSAlisa-Dariana Roman struct spi_transfer t = { 92*2e3ae10cSAlisa-Dariana Roman .len = 0, 93*2e3ae10cSAlisa-Dariana Roman .cs_change = assert, 94*2e3ae10cSAlisa-Dariana Roman }; 95*2e3ae10cSAlisa-Dariana Roman struct spi_message m; 96*2e3ae10cSAlisa-Dariana Roman 97*2e3ae10cSAlisa-Dariana Roman spi_message_init_with_transfers(&m, &t, 1); 98*2e3ae10cSAlisa-Dariana Roman 99*2e3ae10cSAlisa-Dariana Roman return spi_sync_locked(sigma_delta->spi, &m); 100*2e3ae10cSAlisa-Dariana Roman } 101*2e3ae10cSAlisa-Dariana Roman 102*2e3ae10cSAlisa-Dariana Roman static int ad7191_set_mode(struct ad_sigma_delta *sd, 103*2e3ae10cSAlisa-Dariana Roman enum ad_sigma_delta_mode mode) 104*2e3ae10cSAlisa-Dariana Roman { 105*2e3ae10cSAlisa-Dariana Roman struct ad7191_state *st = ad_sigma_delta_to_ad7191(sd); 106*2e3ae10cSAlisa-Dariana Roman 107*2e3ae10cSAlisa-Dariana Roman switch (mode) { 108*2e3ae10cSAlisa-Dariana Roman case AD_SD_MODE_CONTINUOUS: 109*2e3ae10cSAlisa-Dariana Roman case AD_SD_MODE_SINGLE: 110*2e3ae10cSAlisa-Dariana Roman return ad7191_set_cs(&st->sd, 1); 111*2e3ae10cSAlisa-Dariana Roman case AD_SD_MODE_IDLE: 112*2e3ae10cSAlisa-Dariana Roman return ad7191_set_cs(&st->sd, 0); 113*2e3ae10cSAlisa-Dariana Roman default: 114*2e3ae10cSAlisa-Dariana Roman return -EINVAL; 115*2e3ae10cSAlisa-Dariana Roman } 116*2e3ae10cSAlisa-Dariana Roman } 117*2e3ae10cSAlisa-Dariana Roman 118*2e3ae10cSAlisa-Dariana Roman static const struct ad_sigma_delta_info ad7191_sigma_delta_info = { 119*2e3ae10cSAlisa-Dariana Roman .set_channel = ad7191_set_channel, 120*2e3ae10cSAlisa-Dariana Roman .set_mode = ad7191_set_mode, 121*2e3ae10cSAlisa-Dariana Roman .has_registers = false, 122*2e3ae10cSAlisa-Dariana Roman }; 123*2e3ae10cSAlisa-Dariana Roman 124*2e3ae10cSAlisa-Dariana Roman static int ad7191_init_regulators(struct iio_dev *indio_dev) 125*2e3ae10cSAlisa-Dariana Roman { 126*2e3ae10cSAlisa-Dariana Roman struct ad7191_state *st = iio_priv(indio_dev); 127*2e3ae10cSAlisa-Dariana Roman struct device *dev = &st->sd.spi->dev; 128*2e3ae10cSAlisa-Dariana Roman int ret; 129*2e3ae10cSAlisa-Dariana Roman 130*2e3ae10cSAlisa-Dariana Roman ret = devm_regulator_get_enable(dev, "avdd"); 131*2e3ae10cSAlisa-Dariana Roman if (ret) 132*2e3ae10cSAlisa-Dariana Roman return dev_err_probe(dev, ret, "Failed to enable specified AVdd supply\n"); 133*2e3ae10cSAlisa-Dariana Roman 134*2e3ae10cSAlisa-Dariana Roman ret = devm_regulator_get_enable(dev, "dvdd"); 135*2e3ae10cSAlisa-Dariana Roman if (ret) 136*2e3ae10cSAlisa-Dariana Roman return dev_err_probe(dev, ret, "Failed to enable specified DVdd supply\n"); 137*2e3ae10cSAlisa-Dariana Roman 138*2e3ae10cSAlisa-Dariana Roman ret = devm_regulator_get_enable_read_voltage(dev, "vref"); 139*2e3ae10cSAlisa-Dariana Roman if (ret < 0) 140*2e3ae10cSAlisa-Dariana Roman return dev_err_probe(dev, ret, "Failed to get Vref voltage\n"); 141*2e3ae10cSAlisa-Dariana Roman 142*2e3ae10cSAlisa-Dariana Roman st->int_vref_mv = ret / 1000; 143*2e3ae10cSAlisa-Dariana Roman 144*2e3ae10cSAlisa-Dariana Roman return 0; 145*2e3ae10cSAlisa-Dariana Roman } 146*2e3ae10cSAlisa-Dariana Roman 147*2e3ae10cSAlisa-Dariana Roman static int ad7191_config_setup(struct iio_dev *indio_dev) 148*2e3ae10cSAlisa-Dariana Roman { 149*2e3ae10cSAlisa-Dariana Roman struct ad7191_state *st = iio_priv(indio_dev); 150*2e3ae10cSAlisa-Dariana Roman struct device *dev = &st->sd.spi->dev; 151*2e3ae10cSAlisa-Dariana Roman /* Sampling frequencies in Hz, see Table 5 */ 152*2e3ae10cSAlisa-Dariana Roman static const u32 samp_freq[4] = { 120, 60, 50, 10 }; 153*2e3ae10cSAlisa-Dariana Roman /* Gain options, see Table 7 */ 154*2e3ae10cSAlisa-Dariana Roman const u32 gain[4] = { 1, 8, 64, 128 }; 155*2e3ae10cSAlisa-Dariana Roman static u32 scale_buffer[4][2]; 156*2e3ae10cSAlisa-Dariana Roman int odr_value, odr_index = 0, pga_value, pga_index = 0, i, ret; 157*2e3ae10cSAlisa-Dariana Roman u64 scale_uv; 158*2e3ae10cSAlisa-Dariana Roman 159*2e3ae10cSAlisa-Dariana Roman st->samp_freq_index = 0; 160*2e3ae10cSAlisa-Dariana Roman st->scale_index = 0; 161*2e3ae10cSAlisa-Dariana Roman 162*2e3ae10cSAlisa-Dariana Roman ret = device_property_read_u32(dev, "adi,odr-value", &odr_value); 163*2e3ae10cSAlisa-Dariana Roman if (ret && ret != -EINVAL) 164*2e3ae10cSAlisa-Dariana Roman return dev_err_probe(dev, ret, "Failed to get odr value.\n"); 165*2e3ae10cSAlisa-Dariana Roman 166*2e3ae10cSAlisa-Dariana Roman if (ret == -EINVAL) { 167*2e3ae10cSAlisa-Dariana Roman st->odr_gpios = devm_gpiod_get_array(dev, "odr", GPIOD_OUT_LOW); 168*2e3ae10cSAlisa-Dariana Roman if (IS_ERR(st->odr_gpios)) 169*2e3ae10cSAlisa-Dariana Roman return dev_err_probe(dev, PTR_ERR(st->odr_gpios), 170*2e3ae10cSAlisa-Dariana Roman "Failed to get odr gpios.\n"); 171*2e3ae10cSAlisa-Dariana Roman 172*2e3ae10cSAlisa-Dariana Roman if (st->odr_gpios->ndescs != 2) 173*2e3ae10cSAlisa-Dariana Roman return dev_err_probe(dev, -EINVAL, "Expected 2 odr gpio pins.\n"); 174*2e3ae10cSAlisa-Dariana Roman 175*2e3ae10cSAlisa-Dariana Roman st->samp_freq_avail = samp_freq; 176*2e3ae10cSAlisa-Dariana Roman st->samp_freq_avail_size = ARRAY_SIZE(samp_freq); 177*2e3ae10cSAlisa-Dariana Roman } else { 178*2e3ae10cSAlisa-Dariana Roman for (i = 0; i < ARRAY_SIZE(samp_freq); i++) { 179*2e3ae10cSAlisa-Dariana Roman if (odr_value != samp_freq[i]) 180*2e3ae10cSAlisa-Dariana Roman continue; 181*2e3ae10cSAlisa-Dariana Roman odr_index = i; 182*2e3ae10cSAlisa-Dariana Roman break; 183*2e3ae10cSAlisa-Dariana Roman } 184*2e3ae10cSAlisa-Dariana Roman 185*2e3ae10cSAlisa-Dariana Roman st->samp_freq_avail = &samp_freq[odr_index]; 186*2e3ae10cSAlisa-Dariana Roman st->samp_freq_avail_size = 1; 187*2e3ae10cSAlisa-Dariana Roman 188*2e3ae10cSAlisa-Dariana Roman st->odr_gpios = NULL; 189*2e3ae10cSAlisa-Dariana Roman } 190*2e3ae10cSAlisa-Dariana Roman 191*2e3ae10cSAlisa-Dariana Roman mutex_lock(&st->lock); 192*2e3ae10cSAlisa-Dariana Roman 193*2e3ae10cSAlisa-Dariana Roman for (i = 0; i < ARRAY_SIZE(scale_buffer); i++) { 194*2e3ae10cSAlisa-Dariana Roman scale_uv = ((u64)st->int_vref_mv * NANO) >> 195*2e3ae10cSAlisa-Dariana Roman (indio_dev->channels[0].scan_type.realbits - 1); 196*2e3ae10cSAlisa-Dariana Roman do_div(scale_uv, gain[i]); 197*2e3ae10cSAlisa-Dariana Roman scale_buffer[i][1] = do_div(scale_uv, NANO); 198*2e3ae10cSAlisa-Dariana Roman scale_buffer[i][0] = scale_uv; 199*2e3ae10cSAlisa-Dariana Roman } 200*2e3ae10cSAlisa-Dariana Roman 201*2e3ae10cSAlisa-Dariana Roman mutex_unlock(&st->lock); 202*2e3ae10cSAlisa-Dariana Roman 203*2e3ae10cSAlisa-Dariana Roman ret = device_property_read_u32(dev, "adi,pga-value", &pga_value); 204*2e3ae10cSAlisa-Dariana Roman if (ret && ret != -EINVAL) 205*2e3ae10cSAlisa-Dariana Roman return dev_err_probe(dev, ret, "Failed to get pga value.\n"); 206*2e3ae10cSAlisa-Dariana Roman 207*2e3ae10cSAlisa-Dariana Roman if (ret == -EINVAL) { 208*2e3ae10cSAlisa-Dariana Roman st->pga_gpios = devm_gpiod_get_array(dev, "pga", GPIOD_OUT_LOW); 209*2e3ae10cSAlisa-Dariana Roman if (IS_ERR(st->pga_gpios)) 210*2e3ae10cSAlisa-Dariana Roman return dev_err_probe(dev, PTR_ERR(st->pga_gpios), 211*2e3ae10cSAlisa-Dariana Roman "Failed to get pga gpios.\n"); 212*2e3ae10cSAlisa-Dariana Roman 213*2e3ae10cSAlisa-Dariana Roman if (st->pga_gpios->ndescs != 2) 214*2e3ae10cSAlisa-Dariana Roman return dev_err_probe(dev, -EINVAL, "Expected 2 pga gpio pins.\n"); 215*2e3ae10cSAlisa-Dariana Roman 216*2e3ae10cSAlisa-Dariana Roman st->scale_avail = scale_buffer; 217*2e3ae10cSAlisa-Dariana Roman st->scale_avail_size = ARRAY_SIZE(scale_buffer); 218*2e3ae10cSAlisa-Dariana Roman } else { 219*2e3ae10cSAlisa-Dariana Roman for (i = 0; i < ARRAY_SIZE(gain); i++) { 220*2e3ae10cSAlisa-Dariana Roman if (pga_value != gain[i]) 221*2e3ae10cSAlisa-Dariana Roman continue; 222*2e3ae10cSAlisa-Dariana Roman pga_index = i; 223*2e3ae10cSAlisa-Dariana Roman break; 224*2e3ae10cSAlisa-Dariana Roman } 225*2e3ae10cSAlisa-Dariana Roman 226*2e3ae10cSAlisa-Dariana Roman st->scale_avail = &scale_buffer[pga_index]; 227*2e3ae10cSAlisa-Dariana Roman st->scale_avail_size = 1; 228*2e3ae10cSAlisa-Dariana Roman 229*2e3ae10cSAlisa-Dariana Roman st->pga_gpios = NULL; 230*2e3ae10cSAlisa-Dariana Roman } 231*2e3ae10cSAlisa-Dariana Roman 232*2e3ae10cSAlisa-Dariana Roman st->temp_gpio = devm_gpiod_get(dev, "temp", GPIOD_OUT_LOW); 233*2e3ae10cSAlisa-Dariana Roman if (IS_ERR(st->temp_gpio)) 234*2e3ae10cSAlisa-Dariana Roman return dev_err_probe(dev, PTR_ERR(st->temp_gpio), 235*2e3ae10cSAlisa-Dariana Roman "Failed to get temp gpio.\n"); 236*2e3ae10cSAlisa-Dariana Roman 237*2e3ae10cSAlisa-Dariana Roman st->chan_gpio = devm_gpiod_get(dev, "chan", GPIOD_OUT_LOW); 238*2e3ae10cSAlisa-Dariana Roman if (IS_ERR(st->chan_gpio)) 239*2e3ae10cSAlisa-Dariana Roman return dev_err_probe(dev, PTR_ERR(st->chan_gpio), 240*2e3ae10cSAlisa-Dariana Roman "Failed to get chan gpio.\n"); 241*2e3ae10cSAlisa-Dariana Roman 242*2e3ae10cSAlisa-Dariana Roman return 0; 243*2e3ae10cSAlisa-Dariana Roman } 244*2e3ae10cSAlisa-Dariana Roman 245*2e3ae10cSAlisa-Dariana Roman static int ad7191_clock_setup(struct ad7191_state *st) 246*2e3ae10cSAlisa-Dariana Roman { 247*2e3ae10cSAlisa-Dariana Roman struct device *dev = &st->sd.spi->dev; 248*2e3ae10cSAlisa-Dariana Roman 249*2e3ae10cSAlisa-Dariana Roman st->mclk = devm_clk_get_optional_enabled(dev, "mclk"); 250*2e3ae10cSAlisa-Dariana Roman if (IS_ERR(st->mclk)) 251*2e3ae10cSAlisa-Dariana Roman return dev_err_probe(dev, PTR_ERR(st->mclk), 252*2e3ae10cSAlisa-Dariana Roman "Failed to get mclk.\n"); 253*2e3ae10cSAlisa-Dariana Roman 254*2e3ae10cSAlisa-Dariana Roman return 0; 255*2e3ae10cSAlisa-Dariana Roman } 256*2e3ae10cSAlisa-Dariana Roman 257*2e3ae10cSAlisa-Dariana Roman static int ad7191_setup(struct iio_dev *indio_dev) 258*2e3ae10cSAlisa-Dariana Roman { 259*2e3ae10cSAlisa-Dariana Roman struct ad7191_state *st = iio_priv(indio_dev); 260*2e3ae10cSAlisa-Dariana Roman int ret; 261*2e3ae10cSAlisa-Dariana Roman 262*2e3ae10cSAlisa-Dariana Roman ret = ad7191_init_regulators(indio_dev); 263*2e3ae10cSAlisa-Dariana Roman if (ret) 264*2e3ae10cSAlisa-Dariana Roman return ret; 265*2e3ae10cSAlisa-Dariana Roman 266*2e3ae10cSAlisa-Dariana Roman ret = ad7191_config_setup(indio_dev); 267*2e3ae10cSAlisa-Dariana Roman if (ret) 268*2e3ae10cSAlisa-Dariana Roman return ret; 269*2e3ae10cSAlisa-Dariana Roman 270*2e3ae10cSAlisa-Dariana Roman return ad7191_clock_setup(st); 271*2e3ae10cSAlisa-Dariana Roman } 272*2e3ae10cSAlisa-Dariana Roman 273*2e3ae10cSAlisa-Dariana Roman static int ad7191_read_raw(struct iio_dev *indio_dev, 274*2e3ae10cSAlisa-Dariana Roman struct iio_chan_spec const *chan, int *val, 275*2e3ae10cSAlisa-Dariana Roman int *val2, long m) 276*2e3ae10cSAlisa-Dariana Roman { 277*2e3ae10cSAlisa-Dariana Roman struct ad7191_state *st = iio_priv(indio_dev); 278*2e3ae10cSAlisa-Dariana Roman 279*2e3ae10cSAlisa-Dariana Roman switch (m) { 280*2e3ae10cSAlisa-Dariana Roman case IIO_CHAN_INFO_RAW: 281*2e3ae10cSAlisa-Dariana Roman return ad_sigma_delta_single_conversion(indio_dev, chan, val); 282*2e3ae10cSAlisa-Dariana Roman case IIO_CHAN_INFO_SCALE: 283*2e3ae10cSAlisa-Dariana Roman switch (chan->type) { 284*2e3ae10cSAlisa-Dariana Roman case IIO_VOLTAGE: { 285*2e3ae10cSAlisa-Dariana Roman guard(mutex)(&st->lock); 286*2e3ae10cSAlisa-Dariana Roman *val = st->scale_avail[st->scale_index][0]; 287*2e3ae10cSAlisa-Dariana Roman *val2 = st->scale_avail[st->scale_index][1]; 288*2e3ae10cSAlisa-Dariana Roman return IIO_VAL_INT_PLUS_NANO; 289*2e3ae10cSAlisa-Dariana Roman } 290*2e3ae10cSAlisa-Dariana Roman case IIO_TEMP: 291*2e3ae10cSAlisa-Dariana Roman *val = 0; 292*2e3ae10cSAlisa-Dariana Roman *val2 = NANO / AD7191_TEMP_CODES_PER_DEGREE; 293*2e3ae10cSAlisa-Dariana Roman return IIO_VAL_INT_PLUS_NANO; 294*2e3ae10cSAlisa-Dariana Roman default: 295*2e3ae10cSAlisa-Dariana Roman return -EINVAL; 296*2e3ae10cSAlisa-Dariana Roman } 297*2e3ae10cSAlisa-Dariana Roman case IIO_CHAN_INFO_OFFSET: 298*2e3ae10cSAlisa-Dariana Roman *val = -(1 << (chan->scan_type.realbits - 1)); 299*2e3ae10cSAlisa-Dariana Roman switch (chan->type) { 300*2e3ae10cSAlisa-Dariana Roman case IIO_VOLTAGE: 301*2e3ae10cSAlisa-Dariana Roman return IIO_VAL_INT; 302*2e3ae10cSAlisa-Dariana Roman case IIO_TEMP: 303*2e3ae10cSAlisa-Dariana Roman *val -= 273 * AD7191_TEMP_CODES_PER_DEGREE; 304*2e3ae10cSAlisa-Dariana Roman return IIO_VAL_INT; 305*2e3ae10cSAlisa-Dariana Roman default: 306*2e3ae10cSAlisa-Dariana Roman return -EINVAL; 307*2e3ae10cSAlisa-Dariana Roman } 308*2e3ae10cSAlisa-Dariana Roman case IIO_CHAN_INFO_SAMP_FREQ: 309*2e3ae10cSAlisa-Dariana Roman *val = st->samp_freq_avail[st->samp_freq_index]; 310*2e3ae10cSAlisa-Dariana Roman return IIO_VAL_INT; 311*2e3ae10cSAlisa-Dariana Roman default: 312*2e3ae10cSAlisa-Dariana Roman return -EINVAL; 313*2e3ae10cSAlisa-Dariana Roman } 314*2e3ae10cSAlisa-Dariana Roman } 315*2e3ae10cSAlisa-Dariana Roman 316*2e3ae10cSAlisa-Dariana Roman static int ad7191_set_gain(struct ad7191_state *st, int gain_index) 317*2e3ae10cSAlisa-Dariana Roman { 318*2e3ae10cSAlisa-Dariana Roman DECLARE_BITMAP(bitmap, 2) = { }; 319*2e3ae10cSAlisa-Dariana Roman 320*2e3ae10cSAlisa-Dariana Roman st->scale_index = gain_index; 321*2e3ae10cSAlisa-Dariana Roman 322*2e3ae10cSAlisa-Dariana Roman bitmap_write(bitmap, gain_index, 0, 2); 323*2e3ae10cSAlisa-Dariana Roman 324*2e3ae10cSAlisa-Dariana Roman return gpiod_multi_set_value_cansleep(st->pga_gpios, bitmap); 325*2e3ae10cSAlisa-Dariana Roman } 326*2e3ae10cSAlisa-Dariana Roman 327*2e3ae10cSAlisa-Dariana Roman static int ad7191_set_samp_freq(struct ad7191_state *st, int samp_freq_index) 328*2e3ae10cSAlisa-Dariana Roman { 329*2e3ae10cSAlisa-Dariana Roman DECLARE_BITMAP(bitmap, 2) = {}; 330*2e3ae10cSAlisa-Dariana Roman 331*2e3ae10cSAlisa-Dariana Roman st->samp_freq_index = samp_freq_index; 332*2e3ae10cSAlisa-Dariana Roman 333*2e3ae10cSAlisa-Dariana Roman bitmap_write(bitmap, samp_freq_index, 0, 2); 334*2e3ae10cSAlisa-Dariana Roman 335*2e3ae10cSAlisa-Dariana Roman return gpiod_multi_set_value_cansleep(st->odr_gpios, bitmap); 336*2e3ae10cSAlisa-Dariana Roman } 337*2e3ae10cSAlisa-Dariana Roman 338*2e3ae10cSAlisa-Dariana Roman static int __ad7191_write_raw(struct ad7191_state *st, 339*2e3ae10cSAlisa-Dariana Roman struct iio_chan_spec const *chan, 340*2e3ae10cSAlisa-Dariana Roman int val, int val2, long mask) 341*2e3ae10cSAlisa-Dariana Roman { 342*2e3ae10cSAlisa-Dariana Roman int i; 343*2e3ae10cSAlisa-Dariana Roman 344*2e3ae10cSAlisa-Dariana Roman switch (mask) { 345*2e3ae10cSAlisa-Dariana Roman case IIO_CHAN_INFO_SCALE: { 346*2e3ae10cSAlisa-Dariana Roman if (!st->pga_gpios) 347*2e3ae10cSAlisa-Dariana Roman return -EPERM; 348*2e3ae10cSAlisa-Dariana Roman guard(mutex)(&st->lock); 349*2e3ae10cSAlisa-Dariana Roman for (i = 0; i < st->scale_avail_size; i++) { 350*2e3ae10cSAlisa-Dariana Roman if (val2 == st->scale_avail[i][1]) 351*2e3ae10cSAlisa-Dariana Roman return ad7191_set_gain(st, i); 352*2e3ae10cSAlisa-Dariana Roman } 353*2e3ae10cSAlisa-Dariana Roman return -EINVAL; 354*2e3ae10cSAlisa-Dariana Roman } 355*2e3ae10cSAlisa-Dariana Roman case IIO_CHAN_INFO_SAMP_FREQ: { 356*2e3ae10cSAlisa-Dariana Roman if (!st->odr_gpios) 357*2e3ae10cSAlisa-Dariana Roman return -EPERM; 358*2e3ae10cSAlisa-Dariana Roman guard(mutex)(&st->lock); 359*2e3ae10cSAlisa-Dariana Roman for (i = 0; i < st->samp_freq_avail_size; i++) { 360*2e3ae10cSAlisa-Dariana Roman if (val == st->samp_freq_avail[i]) 361*2e3ae10cSAlisa-Dariana Roman return ad7191_set_samp_freq(st, i); 362*2e3ae10cSAlisa-Dariana Roman } 363*2e3ae10cSAlisa-Dariana Roman return -EINVAL; 364*2e3ae10cSAlisa-Dariana Roman } 365*2e3ae10cSAlisa-Dariana Roman default: 366*2e3ae10cSAlisa-Dariana Roman return -EINVAL; 367*2e3ae10cSAlisa-Dariana Roman } 368*2e3ae10cSAlisa-Dariana Roman } 369*2e3ae10cSAlisa-Dariana Roman 370*2e3ae10cSAlisa-Dariana Roman static int ad7191_write_raw(struct iio_dev *indio_dev, 371*2e3ae10cSAlisa-Dariana Roman struct iio_chan_spec const *chan, int val, int val2, 372*2e3ae10cSAlisa-Dariana Roman long mask) 373*2e3ae10cSAlisa-Dariana Roman { 374*2e3ae10cSAlisa-Dariana Roman struct ad7191_state *st = iio_priv(indio_dev); 375*2e3ae10cSAlisa-Dariana Roman int ret; 376*2e3ae10cSAlisa-Dariana Roman 377*2e3ae10cSAlisa-Dariana Roman if (!iio_device_claim_direct(indio_dev)) 378*2e3ae10cSAlisa-Dariana Roman return -EBUSY; 379*2e3ae10cSAlisa-Dariana Roman 380*2e3ae10cSAlisa-Dariana Roman ret = __ad7191_write_raw(st, chan, val, val2, mask); 381*2e3ae10cSAlisa-Dariana Roman 382*2e3ae10cSAlisa-Dariana Roman iio_device_release_direct(indio_dev); 383*2e3ae10cSAlisa-Dariana Roman 384*2e3ae10cSAlisa-Dariana Roman return ret; 385*2e3ae10cSAlisa-Dariana Roman } 386*2e3ae10cSAlisa-Dariana Roman 387*2e3ae10cSAlisa-Dariana Roman static int ad7191_write_raw_get_fmt(struct iio_dev *indio_dev, 388*2e3ae10cSAlisa-Dariana Roman struct iio_chan_spec const *chan, long mask) 389*2e3ae10cSAlisa-Dariana Roman { 390*2e3ae10cSAlisa-Dariana Roman switch (mask) { 391*2e3ae10cSAlisa-Dariana Roman case IIO_CHAN_INFO_SCALE: 392*2e3ae10cSAlisa-Dariana Roman return IIO_VAL_INT_PLUS_NANO; 393*2e3ae10cSAlisa-Dariana Roman case IIO_CHAN_INFO_SAMP_FREQ: 394*2e3ae10cSAlisa-Dariana Roman return IIO_VAL_INT; 395*2e3ae10cSAlisa-Dariana Roman default: 396*2e3ae10cSAlisa-Dariana Roman return -EINVAL; 397*2e3ae10cSAlisa-Dariana Roman } 398*2e3ae10cSAlisa-Dariana Roman } 399*2e3ae10cSAlisa-Dariana Roman 400*2e3ae10cSAlisa-Dariana Roman static int ad7191_read_avail(struct iio_dev *indio_dev, 401*2e3ae10cSAlisa-Dariana Roman struct iio_chan_spec const *chan, const int **vals, 402*2e3ae10cSAlisa-Dariana Roman int *type, int *length, long mask) 403*2e3ae10cSAlisa-Dariana Roman { 404*2e3ae10cSAlisa-Dariana Roman struct ad7191_state *st = iio_priv(indio_dev); 405*2e3ae10cSAlisa-Dariana Roman 406*2e3ae10cSAlisa-Dariana Roman switch (mask) { 407*2e3ae10cSAlisa-Dariana Roman case IIO_CHAN_INFO_SCALE: 408*2e3ae10cSAlisa-Dariana Roman *vals = (int *)st->scale_avail; 409*2e3ae10cSAlisa-Dariana Roman *type = IIO_VAL_INT_PLUS_NANO; 410*2e3ae10cSAlisa-Dariana Roman *length = st->scale_avail_size * 2; 411*2e3ae10cSAlisa-Dariana Roman return IIO_AVAIL_LIST; 412*2e3ae10cSAlisa-Dariana Roman case IIO_CHAN_INFO_SAMP_FREQ: 413*2e3ae10cSAlisa-Dariana Roman *vals = (int *)st->samp_freq_avail; 414*2e3ae10cSAlisa-Dariana Roman *type = IIO_VAL_INT; 415*2e3ae10cSAlisa-Dariana Roman *length = st->samp_freq_avail_size; 416*2e3ae10cSAlisa-Dariana Roman return IIO_AVAIL_LIST; 417*2e3ae10cSAlisa-Dariana Roman } 418*2e3ae10cSAlisa-Dariana Roman 419*2e3ae10cSAlisa-Dariana Roman return -EINVAL; 420*2e3ae10cSAlisa-Dariana Roman } 421*2e3ae10cSAlisa-Dariana Roman 422*2e3ae10cSAlisa-Dariana Roman static const struct iio_info ad7191_info = { 423*2e3ae10cSAlisa-Dariana Roman .read_raw = ad7191_read_raw, 424*2e3ae10cSAlisa-Dariana Roman .write_raw = ad7191_write_raw, 425*2e3ae10cSAlisa-Dariana Roman .write_raw_get_fmt = ad7191_write_raw_get_fmt, 426*2e3ae10cSAlisa-Dariana Roman .read_avail = ad7191_read_avail, 427*2e3ae10cSAlisa-Dariana Roman .validate_trigger = ad_sd_validate_trigger, 428*2e3ae10cSAlisa-Dariana Roman }; 429*2e3ae10cSAlisa-Dariana Roman 430*2e3ae10cSAlisa-Dariana Roman static const struct iio_chan_spec ad7191_channels[] = { 431*2e3ae10cSAlisa-Dariana Roman { 432*2e3ae10cSAlisa-Dariana Roman .type = IIO_TEMP, 433*2e3ae10cSAlisa-Dariana Roman .address = AD7191_CH_TEMP, 434*2e3ae10cSAlisa-Dariana Roman .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) | 435*2e3ae10cSAlisa-Dariana Roman BIT(IIO_CHAN_INFO_OFFSET) | 436*2e3ae10cSAlisa-Dariana Roman BIT(IIO_CHAN_INFO_SAMP_FREQ), 437*2e3ae10cSAlisa-Dariana Roman .info_mask_shared_by_all_available = BIT(IIO_CHAN_INFO_SAMP_FREQ), 438*2e3ae10cSAlisa-Dariana Roman .info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE), 439*2e3ae10cSAlisa-Dariana Roman .scan_type = { 440*2e3ae10cSAlisa-Dariana Roman .sign = 'u', 441*2e3ae10cSAlisa-Dariana Roman .realbits = 24, 442*2e3ae10cSAlisa-Dariana Roman .storagebits = 32, 443*2e3ae10cSAlisa-Dariana Roman .endianness = IIO_BE, 444*2e3ae10cSAlisa-Dariana Roman }, 445*2e3ae10cSAlisa-Dariana Roman }, 446*2e3ae10cSAlisa-Dariana Roman { 447*2e3ae10cSAlisa-Dariana Roman .type = IIO_VOLTAGE, 448*2e3ae10cSAlisa-Dariana Roman .differential = 1, 449*2e3ae10cSAlisa-Dariana Roman .indexed = 1, 450*2e3ae10cSAlisa-Dariana Roman .channel = 1, 451*2e3ae10cSAlisa-Dariana Roman .channel2 = 2, 452*2e3ae10cSAlisa-Dariana Roman .address = AD7191_CH_AIN1_AIN2, 453*2e3ae10cSAlisa-Dariana Roman .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) | 454*2e3ae10cSAlisa-Dariana Roman BIT(IIO_CHAN_INFO_OFFSET) | 455*2e3ae10cSAlisa-Dariana Roman BIT(IIO_CHAN_INFO_SAMP_FREQ), 456*2e3ae10cSAlisa-Dariana Roman .info_mask_shared_by_all_available = BIT(IIO_CHAN_INFO_SAMP_FREQ), 457*2e3ae10cSAlisa-Dariana Roman .info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE), 458*2e3ae10cSAlisa-Dariana Roman .info_mask_shared_by_type_available = BIT(IIO_CHAN_INFO_SCALE), 459*2e3ae10cSAlisa-Dariana Roman .scan_index = 1, 460*2e3ae10cSAlisa-Dariana Roman .scan_type = { 461*2e3ae10cSAlisa-Dariana Roman .sign = 'u', 462*2e3ae10cSAlisa-Dariana Roman .realbits = 24, 463*2e3ae10cSAlisa-Dariana Roman .storagebits = 32, 464*2e3ae10cSAlisa-Dariana Roman .endianness = IIO_BE, 465*2e3ae10cSAlisa-Dariana Roman }, 466*2e3ae10cSAlisa-Dariana Roman }, 467*2e3ae10cSAlisa-Dariana Roman { 468*2e3ae10cSAlisa-Dariana Roman .type = IIO_VOLTAGE, 469*2e3ae10cSAlisa-Dariana Roman .differential = 1, 470*2e3ae10cSAlisa-Dariana Roman .indexed = 1, 471*2e3ae10cSAlisa-Dariana Roman .channel = 3, 472*2e3ae10cSAlisa-Dariana Roman .channel2 = 4, 473*2e3ae10cSAlisa-Dariana Roman .address = AD7191_CH_AIN3_AIN4, 474*2e3ae10cSAlisa-Dariana Roman .info_mask_separate = BIT(IIO_CHAN_INFO_RAW) | 475*2e3ae10cSAlisa-Dariana Roman BIT(IIO_CHAN_INFO_OFFSET) | 476*2e3ae10cSAlisa-Dariana Roman BIT(IIO_CHAN_INFO_SAMP_FREQ), 477*2e3ae10cSAlisa-Dariana Roman .info_mask_shared_by_all_available = BIT(IIO_CHAN_INFO_SAMP_FREQ), 478*2e3ae10cSAlisa-Dariana Roman .info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SCALE), 479*2e3ae10cSAlisa-Dariana Roman .info_mask_shared_by_type_available = BIT(IIO_CHAN_INFO_SCALE), 480*2e3ae10cSAlisa-Dariana Roman .scan_index = 2, 481*2e3ae10cSAlisa-Dariana Roman .scan_type = { 482*2e3ae10cSAlisa-Dariana Roman .sign = 'u', 483*2e3ae10cSAlisa-Dariana Roman .realbits = 24, 484*2e3ae10cSAlisa-Dariana Roman .storagebits = 32, 485*2e3ae10cSAlisa-Dariana Roman .endianness = IIO_BE, 486*2e3ae10cSAlisa-Dariana Roman }, 487*2e3ae10cSAlisa-Dariana Roman }, 488*2e3ae10cSAlisa-Dariana Roman IIO_CHAN_SOFT_TIMESTAMP(3), 489*2e3ae10cSAlisa-Dariana Roman }; 490*2e3ae10cSAlisa-Dariana Roman 491*2e3ae10cSAlisa-Dariana Roman static int ad7191_probe(struct spi_device *spi) 492*2e3ae10cSAlisa-Dariana Roman { 493*2e3ae10cSAlisa-Dariana Roman struct device *dev = &spi->dev; 494*2e3ae10cSAlisa-Dariana Roman struct ad7191_state *st; 495*2e3ae10cSAlisa-Dariana Roman struct iio_dev *indio_dev; 496*2e3ae10cSAlisa-Dariana Roman int ret; 497*2e3ae10cSAlisa-Dariana Roman 498*2e3ae10cSAlisa-Dariana Roman indio_dev = devm_iio_device_alloc(dev, sizeof(*st)); 499*2e3ae10cSAlisa-Dariana Roman if (!indio_dev) 500*2e3ae10cSAlisa-Dariana Roman return -ENOMEM; 501*2e3ae10cSAlisa-Dariana Roman 502*2e3ae10cSAlisa-Dariana Roman st = iio_priv(indio_dev); 503*2e3ae10cSAlisa-Dariana Roman 504*2e3ae10cSAlisa-Dariana Roman ret = devm_mutex_init(dev, &st->lock); 505*2e3ae10cSAlisa-Dariana Roman if (ret) 506*2e3ae10cSAlisa-Dariana Roman return ret; 507*2e3ae10cSAlisa-Dariana Roman 508*2e3ae10cSAlisa-Dariana Roman indio_dev->name = "ad7191"; 509*2e3ae10cSAlisa-Dariana Roman indio_dev->modes = INDIO_DIRECT_MODE; 510*2e3ae10cSAlisa-Dariana Roman indio_dev->channels = ad7191_channels; 511*2e3ae10cSAlisa-Dariana Roman indio_dev->num_channels = ARRAY_SIZE(ad7191_channels); 512*2e3ae10cSAlisa-Dariana Roman indio_dev->info = &ad7191_info; 513*2e3ae10cSAlisa-Dariana Roman 514*2e3ae10cSAlisa-Dariana Roman ret = ad_sd_init(&st->sd, indio_dev, spi, &ad7191_sigma_delta_info); 515*2e3ae10cSAlisa-Dariana Roman if (ret) 516*2e3ae10cSAlisa-Dariana Roman return ret; 517*2e3ae10cSAlisa-Dariana Roman 518*2e3ae10cSAlisa-Dariana Roman ret = devm_ad_sd_setup_buffer_and_trigger(dev, indio_dev); 519*2e3ae10cSAlisa-Dariana Roman if (ret) 520*2e3ae10cSAlisa-Dariana Roman return ret; 521*2e3ae10cSAlisa-Dariana Roman 522*2e3ae10cSAlisa-Dariana Roman ret = ad7191_setup(indio_dev); 523*2e3ae10cSAlisa-Dariana Roman if (ret) 524*2e3ae10cSAlisa-Dariana Roman return ret; 525*2e3ae10cSAlisa-Dariana Roman 526*2e3ae10cSAlisa-Dariana Roman return devm_iio_device_register(dev, indio_dev); 527*2e3ae10cSAlisa-Dariana Roman } 528*2e3ae10cSAlisa-Dariana Roman 529*2e3ae10cSAlisa-Dariana Roman static const struct of_device_id ad7191_of_match[] = { 530*2e3ae10cSAlisa-Dariana Roman { .compatible = "adi,ad7191", }, 531*2e3ae10cSAlisa-Dariana Roman { } 532*2e3ae10cSAlisa-Dariana Roman }; 533*2e3ae10cSAlisa-Dariana Roman MODULE_DEVICE_TABLE(of, ad7191_of_match); 534*2e3ae10cSAlisa-Dariana Roman 535*2e3ae10cSAlisa-Dariana Roman static const struct spi_device_id ad7191_id_table[] = { 536*2e3ae10cSAlisa-Dariana Roman { "ad7191" }, 537*2e3ae10cSAlisa-Dariana Roman { } 538*2e3ae10cSAlisa-Dariana Roman }; 539*2e3ae10cSAlisa-Dariana Roman MODULE_DEVICE_TABLE(spi, ad7191_id_table); 540*2e3ae10cSAlisa-Dariana Roman 541*2e3ae10cSAlisa-Dariana Roman static struct spi_driver ad7191_driver = { 542*2e3ae10cSAlisa-Dariana Roman .driver = { 543*2e3ae10cSAlisa-Dariana Roman .name = "ad7191", 544*2e3ae10cSAlisa-Dariana Roman .of_match_table = ad7191_of_match, 545*2e3ae10cSAlisa-Dariana Roman }, 546*2e3ae10cSAlisa-Dariana Roman .probe = ad7191_probe, 547*2e3ae10cSAlisa-Dariana Roman .id_table = ad7191_id_table, 548*2e3ae10cSAlisa-Dariana Roman }; 549*2e3ae10cSAlisa-Dariana Roman module_spi_driver(ad7191_driver); 550*2e3ae10cSAlisa-Dariana Roman 551*2e3ae10cSAlisa-Dariana Roman MODULE_AUTHOR("Alisa-Dariana Roman <alisa.roman@analog.com>"); 552*2e3ae10cSAlisa-Dariana Roman MODULE_DESCRIPTION("Analog Devices AD7191 ADC"); 553*2e3ae10cSAlisa-Dariana Roman MODULE_LICENSE("GPL"); 554*2e3ae10cSAlisa-Dariana Roman MODULE_IMPORT_NS("IIO_AD_SIGMA_DELTA"); 555