Commit 9324131b authored by Lars-Peter Clausen's avatar Lars-Peter Clausen Committed by Jonathan Cameron

staging:iio:ad7606: Report scale as fractional value

Move the complexity of calculating the fixed point scale to the core.
Signed-off-by: default avatarLars-Peter Clausen <lars@metafoo.de>
Signed-off-by: default avatarJonathan Cameron <jic23@kernel.org>
parent d6570b33
...@@ -85,7 +85,6 @@ static int ad7606_read_raw(struct iio_dev *indio_dev, ...@@ -85,7 +85,6 @@ static int ad7606_read_raw(struct iio_dev *indio_dev,
{ {
int ret; int ret;
struct ad7606_state *st = iio_priv(indio_dev); struct ad7606_state *st = iio_priv(indio_dev);
unsigned int scale_uv;
switch (m) { switch (m) {
case IIO_CHAN_INFO_RAW: case IIO_CHAN_INFO_RAW:
...@@ -101,11 +100,9 @@ static int ad7606_read_raw(struct iio_dev *indio_dev, ...@@ -101,11 +100,9 @@ static int ad7606_read_raw(struct iio_dev *indio_dev,
*val = (short) ret; *val = (short) ret;
return IIO_VAL_INT; return IIO_VAL_INT;
case IIO_CHAN_INFO_SCALE: case IIO_CHAN_INFO_SCALE:
scale_uv = (st->range * 1000 * 2) *val = st->range * 2;
>> st->chip_info->channels[0].scan_type.realbits; *val2 = st->chip_info->channels[0].scan_type.realbits;
*val = scale_uv / 1000; return IIO_VAL_FRACTIONAL_LOG2;
*val2 = (scale_uv % 1000) * 1000;
return IIO_VAL_INT_PLUS_MICRO;
} }
return -EINVAL; return -EINVAL;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment