Lines Matching +full:vref +full:- +full:p
1 // SPDX-License-Identifier: GPL-2.0-only
5 * Copyright (c) 2013-2015 Intel Corporation.
29 * In case of ACPI, we use the hard-wired 5000 mV of the Galileo and IOT2000
31 * via the vref-supply regulator.
38 * chips. The ADC108S102 effectively returns a 12-bit result with the 2
39 * least-significant bits unset.
45 * 16-bit SPI command format:
47 * [13:11] 3-bit channel address
53 * 16-bit SPI response format:
55 * [11:0] 12-bit ADC sample (for ADC108S102, [1:0] will always be 0).
125 st->tx_buf[cmds++] = cpu_to_be16(ADC108S102_CMD(bit)); in adc108s102_update_scan_mode()
128 st->tx_buf[cmds++] = 0x00; in adc108s102_update_scan_mode()
131 st->ring_xfer.tx_buf = &st->tx_buf[0]; in adc108s102_update_scan_mode()
132 st->ring_xfer.rx_buf = &st->rx_buf[0]; in adc108s102_update_scan_mode()
133 st->ring_xfer.len = cmds * sizeof(st->tx_buf[0]); in adc108s102_update_scan_mode()
135 spi_message_init_with_transfers(&st->ring_msg, &st->ring_xfer, 1); in adc108s102_update_scan_mode()
140 static irqreturn_t adc108s102_trigger_handler(int irq, void *p) in adc108s102_trigger_handler() argument
142 struct iio_poll_func *pf = p; in adc108s102_trigger_handler()
143 struct iio_dev *indio_dev = pf->indio_dev; in adc108s102_trigger_handler()
147 ret = spi_sync(st->spi, &st->ring_msg); in adc108s102_trigger_handler()
153 &st->rx_buf[1], in adc108s102_trigger_handler()
154 st->ring_xfer.len - sizeof(st->rx_buf[1]), in adc108s102_trigger_handler()
158 iio_trigger_notify_done(indio_dev->trig); in adc108s102_trigger_handler()
167 st->tx_buf[0] = cpu_to_be16(ADC108S102_CMD(ch)); in adc108s102_scan_direct()
168 ret = spi_sync(st->spi, &st->scan_single_msg); in adc108s102_scan_direct()
173 return be16_to_cpu(st->rx_buf[1]); in adc108s102_scan_direct()
189 ret = adc108s102_scan_direct(st, chan->address); in adc108s102_read_raw()
200 if (chan->type != IIO_VOLTAGE) in adc108s102_read_raw()
203 *val = st->va_millivolt; in adc108s102_read_raw()
204 *val2 = chan->scan_type.realbits; in adc108s102_read_raw()
211 return -EINVAL; in adc108s102_read_raw()
230 indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); in adc108s102_probe()
232 return -ENOMEM; in adc108s102_probe()
236 if (ACPI_COMPANION(&spi->dev)) { in adc108s102_probe()
237 st->va_millivolt = ADC108S102_VA_MV_ACPI_DEFAULT; in adc108s102_probe()
239 st->reg = devm_regulator_get(&spi->dev, "vref"); in adc108s102_probe()
240 if (IS_ERR(st->reg)) in adc108s102_probe()
241 return PTR_ERR(st->reg); in adc108s102_probe()
243 ret = regulator_enable(st->reg); in adc108s102_probe()
245 dev_err(&spi->dev, "Cannot enable vref regulator\n"); in adc108s102_probe()
248 ret = devm_add_action_or_reset(&spi->dev, adc108s102_reg_disable, in adc108s102_probe()
249 st->reg); in adc108s102_probe()
253 ret = regulator_get_voltage(st->reg); in adc108s102_probe()
255 dev_err(&spi->dev, "vref get voltage failed\n"); in adc108s102_probe()
259 st->va_millivolt = ret / 1000; in adc108s102_probe()
262 st->spi = spi; in adc108s102_probe()
264 indio_dev->name = spi->modalias; in adc108s102_probe()
265 indio_dev->modes = INDIO_DIRECT_MODE; in adc108s102_probe()
266 indio_dev->channels = adc108s102_channels; in adc108s102_probe()
267 indio_dev->num_channels = ARRAY_SIZE(adc108s102_channels); in adc108s102_probe()
268 indio_dev->info = &adc108s102_info; in adc108s102_probe()
271 st->scan_single_xfer.tx_buf = st->tx_buf; in adc108s102_probe()
272 st->scan_single_xfer.rx_buf = st->rx_buf; in adc108s102_probe()
273 st->scan_single_xfer.len = 2 * sizeof(st->tx_buf[0]); in adc108s102_probe()
275 spi_message_init_with_transfers(&st->scan_single_msg, in adc108s102_probe()
276 &st->scan_single_xfer, 1); in adc108s102_probe()
278 ret = devm_iio_triggered_buffer_setup(&spi->dev, indio_dev, NULL, in adc108s102_probe()
284 ret = devm_iio_device_register(&spi->dev, indio_dev); in adc108s102_probe()
286 dev_err(&spi->dev, "Failed to register IIO device\n"); in adc108s102_probe()