Lines Matching +full:rx +full:- +full:sample +full:- +full:delay +full:- +full:ns

1 // SPDX-License-Identifier: GPL-2.0-only
6 * Copyright (c) 2018-2018 David Veenstra <davidjulianveenstra@gmail.com>
7 * Copyright (c) 2010-2010 Analog Devices Inc.
11 #include <linux/delay.h>
31 * struct ad2s1200_state - driver instance specific data.
32 * @lock: protects both the GPIO pins and the rx buffer.
34 * @sample: GPIO pin SAMPLE.
36 * @rx: buffer for spi transfers.
41 struct gpio_desc *sample; member
43 __be16 rx __aligned(IIO_DMA_MINALIGN);
57 switch (chan->type) { in ad2s1200_read_raw()
59 /* 2 * Pi / (2^12 - 1) ~= 0.001534355 */ in ad2s1200_read_raw()
69 return -EINVAL; in ad2s1200_read_raw()
73 mutex_lock(&st->lock); in ad2s1200_read_raw()
74 gpiod_set_value(st->sample, 0); in ad2s1200_read_raw()
76 /* delay (6 * AD2S1200_TSCLK + 20) nano seconds */ in ad2s1200_read_raw()
78 gpiod_set_value(st->sample, 1); in ad2s1200_read_raw()
79 gpiod_set_value(st->rdvel, !!(chan->type == IIO_ANGL)); in ad2s1200_read_raw()
81 ret = spi_read(st->sdev, &st->rx, 2); in ad2s1200_read_raw()
83 mutex_unlock(&st->lock); in ad2s1200_read_raw()
87 switch (chan->type) { in ad2s1200_read_raw()
89 *val = be16_to_cpup(&st->rx) >> 4; in ad2s1200_read_raw()
92 *val = sign_extend32(be16_to_cpup(&st->rx) >> 4, 11); in ad2s1200_read_raw()
95 mutex_unlock(&st->lock); in ad2s1200_read_raw()
96 return -EINVAL; in ad2s1200_read_raw()
99 /* delay (2 * AD2S1200_TSCLK + 20) ns for sample pulse */ in ad2s1200_read_raw()
101 mutex_unlock(&st->lock); in ad2s1200_read_raw()
108 return -EINVAL; in ad2s1200_read_raw()
137 indio_dev = devm_iio_device_alloc(&spi->dev, sizeof(*st)); in ad2s1200_probe()
139 return -ENOMEM; in ad2s1200_probe()
143 mutex_init(&st->lock); in ad2s1200_probe()
144 st->sdev = spi; in ad2s1200_probe()
146 st->sample = devm_gpiod_get(&spi->dev, "adi,sample", GPIOD_OUT_LOW); in ad2s1200_probe()
147 if (IS_ERR(st->sample)) { in ad2s1200_probe()
148 dev_err(&spi->dev, "Failed to claim SAMPLE gpio: err=%ld\n", in ad2s1200_probe()
149 PTR_ERR(st->sample)); in ad2s1200_probe()
150 return PTR_ERR(st->sample); in ad2s1200_probe()
153 st->rdvel = devm_gpiod_get(&spi->dev, "adi,rdvel", GPIOD_OUT_LOW); in ad2s1200_probe()
154 if (IS_ERR(st->rdvel)) { in ad2s1200_probe()
155 dev_err(&spi->dev, "Failed to claim RDVEL gpio: err=%ld\n", in ad2s1200_probe()
156 PTR_ERR(st->rdvel)); in ad2s1200_probe()
157 return PTR_ERR(st->rdvel); in ad2s1200_probe()
160 indio_dev->info = &ad2s1200_info; in ad2s1200_probe()
161 indio_dev->modes = INDIO_DIRECT_MODE; in ad2s1200_probe()
162 indio_dev->channels = ad2s1200_channels; in ad2s1200_probe()
163 indio_dev->num_channels = ARRAY_SIZE(ad2s1200_channels); in ad2s1200_probe()
164 indio_dev->name = spi_get_device_id(spi)->name; in ad2s1200_probe()
166 spi->max_speed_hz = AD2S1200_HZ; in ad2s1200_probe()
167 spi->mode = SPI_MODE_3; in ad2s1200_probe()
171 dev_err(&spi->dev, "spi_setup failed!\n"); in ad2s1200_probe()
175 return devm_iio_device_register(&spi->dev, indio_dev); in ad2s1200_probe()