7f83e105bd
[ Upstream commit b73f08bb7fe5a0901646ca5ceaa1e7a2d5ee6293 ] When reading in_voltage_scale we can get something like: root@analog:/sys/bus/iio/devices/iio:device2# cat in_voltage_scale 0.038146 However, when reading the available options: root@analog:/sys/bus/iio/devices/iio:device2# cat in_voltage_scale_available 2000.000000 2100.000006 2200.000007 2300.000008 2400.000009 2500.000010 which does not make sense. Moreover, when trying to set a new scale we get an error because there's no call to __ad9467_get_scale() to give us values as given when reading in_voltage_scale. Fix it by computing the available scales during probe and properly pass the list when .read_available() is called. While at it, change to use .read_available() from iio_info. Also note that to properly fix this, adi-axi-adc.c has to be changed accordingly. Fixes: ad6797120238 ("iio: adc: ad9467: add support AD9467 ADC") Signed-off-by: Nuno Sa <nuno.sa@analog.com> Reviewed-by: David Lechner <dlechner@baylibre.com> Link: https://lore.kernel.org/r/20231207-iio-backend-prep-v2-4-a4a33bc4d70e@analog.com Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
68 lines
2.1 KiB
C
Executable file
68 lines
2.1 KiB
C
Executable file
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Analog Devices Generic AXI ADC IP core driver/library
|
|
* Link: https://wiki.analog.com/resources/fpga/docs/axi_adc_ip
|
|
*
|
|
* Copyright 2012-2020 Analog Devices Inc.
|
|
*/
|
|
#ifndef __ADI_AXI_ADC_H__
|
|
#define __ADI_AXI_ADC_H__
|
|
|
|
struct device;
|
|
struct iio_chan_spec;
|
|
|
|
/**
|
|
* struct adi_axi_adc_chip_info - Chip specific information
|
|
* @name Chip name
|
|
* @id Chip ID (usually product ID)
|
|
* @channels Channel specifications of type @struct axi_adc_chan_spec
|
|
* @num_channels Number of @channels
|
|
* @scale_table Supported scales by the chip; tuples of 2 ints
|
|
* @num_scales Number of scales in the table
|
|
* @max_rate Maximum sampling rate supported by the device
|
|
*/
|
|
struct adi_axi_adc_chip_info {
|
|
const char *name;
|
|
unsigned int id;
|
|
|
|
const struct iio_chan_spec *channels;
|
|
unsigned int num_channels;
|
|
|
|
const unsigned int (*scale_table)[2];
|
|
int num_scales;
|
|
|
|
unsigned long max_rate;
|
|
};
|
|
|
|
/**
|
|
* struct adi_axi_adc_conv - data of the ADC attached to the AXI ADC
|
|
* @chip_info chip info details for the client ADC
|
|
* @preenable_setup op to run in the client before enabling the AXI ADC
|
|
* @reg_access IIO debugfs_reg_access hook for the client ADC
|
|
* @read_raw IIO read_raw hook for the client ADC
|
|
* @write_raw IIO write_raw hook for the client ADC
|
|
* @read_avail IIO read_avail hook for the client ADC
|
|
*/
|
|
struct adi_axi_adc_conv {
|
|
const struct adi_axi_adc_chip_info *chip_info;
|
|
|
|
int (*preenable_setup)(struct adi_axi_adc_conv *conv);
|
|
int (*reg_access)(struct adi_axi_adc_conv *conv, unsigned int reg,
|
|
unsigned int writeval, unsigned int *readval);
|
|
int (*read_raw)(struct adi_axi_adc_conv *conv,
|
|
struct iio_chan_spec const *chan,
|
|
int *val, int *val2, long mask);
|
|
int (*write_raw)(struct adi_axi_adc_conv *conv,
|
|
struct iio_chan_spec const *chan,
|
|
int val, int val2, long mask);
|
|
int (*read_avail)(struct adi_axi_adc_conv *conv,
|
|
struct iio_chan_spec const *chan,
|
|
const int **val, int *type, int *length, long mask);
|
|
};
|
|
|
|
struct adi_axi_adc_conv *devm_adi_axi_adc_conv_register(struct device *dev,
|
|
size_t sizeof_priv);
|
|
|
|
void *adi_axi_adc_conv_priv(struct adi_axi_adc_conv *conv);
|
|
|
|
#endif
|