Re: [PATCH] iio: st_sensors: fix scale configuration for h3lis331dl

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 25/10/16 22:07, Lorenzo Bianconi wrote:
> fix scale configuration/parsing for h3lis331dl accel driver
> when sensitivity is higher than 1(m/s^2)/digit
> 
> Signed-off-by: Lorenzo Bianconi <lorenzo.bianconi@xxxxxx>
Ideally would have had a fixes tag (I added one hopefully to
the right patch ;)

Applied to the fixes-togreg branch of iio.git and marked for stable.

Thanks,

Jonathan
> ---
>  drivers/iio/accel/st_accel_core.c               | 12 ++++++++----
>  drivers/iio/common/st_sensors/st_sensors_core.c |  8 +++++---
>  2 files changed, 13 insertions(+), 7 deletions(-)
> 
> diff --git a/drivers/iio/accel/st_accel_core.c b/drivers/iio/accel/st_accel_core.c
> index da3fb06..ce69048 100644
> --- a/drivers/iio/accel/st_accel_core.c
> +++ b/drivers/iio/accel/st_accel_core.c
> @@ -743,8 +743,8 @@ static int st_accel_read_raw(struct iio_dev *indio_dev,
>  
>  		return IIO_VAL_INT;
>  	case IIO_CHAN_INFO_SCALE:
> -		*val = 0;
> -		*val2 = adata->current_fullscale->gain;
> +		*val = adata->current_fullscale->gain / 1000000;
> +		*val2 = adata->current_fullscale->gain % 1000000;
>  		return IIO_VAL_INT_PLUS_MICRO;
>  	case IIO_CHAN_INFO_SAMP_FREQ:
>  		*val = adata->odr;
> @@ -763,9 +763,13 @@ static int st_accel_write_raw(struct iio_dev *indio_dev,
>  	int err;
>  
>  	switch (mask) {
> -	case IIO_CHAN_INFO_SCALE:
> -		err = st_sensors_set_fullscale_by_gain(indio_dev, val2);
> +	case IIO_CHAN_INFO_SCALE: {
> +		int gain;
> +
> +		gain = val * 1000000 + val2;
> +		err = st_sensors_set_fullscale_by_gain(indio_dev, gain);
>  		break;
> +	}
>  	case IIO_CHAN_INFO_SAMP_FREQ:
>  		if (val2)
>  			return -EINVAL;
> diff --git a/drivers/iio/common/st_sensors/st_sensors_core.c b/drivers/iio/common/st_sensors/st_sensors_core.c
> index 285a64a..975a1f1 100644
> --- a/drivers/iio/common/st_sensors/st_sensors_core.c
> +++ b/drivers/iio/common/st_sensors/st_sensors_core.c
> @@ -612,7 +612,7 @@ EXPORT_SYMBOL(st_sensors_sysfs_sampling_frequency_avail);
>  ssize_t st_sensors_sysfs_scale_avail(struct device *dev,
>  				struct device_attribute *attr, char *buf)
>  {
> -	int i, len = 0;
> +	int i, len = 0, q, r;
>  	struct iio_dev *indio_dev = dev_get_drvdata(dev);
>  	struct st_sensor_data *sdata = iio_priv(indio_dev);
>  
> @@ -621,8 +621,10 @@ ssize_t st_sensors_sysfs_scale_avail(struct device *dev,
>  		if (sdata->sensor_settings->fs.fs_avl[i].num == 0)
>  			break;
>  
> -		len += scnprintf(buf + len, PAGE_SIZE - len, "0.%06u ",
> -				sdata->sensor_settings->fs.fs_avl[i].gain);
> +		q = sdata->sensor_settings->fs.fs_avl[i].gain / 1000000;
> +		r = sdata->sensor_settings->fs.fs_avl[i].gain % 1000000;
> +
> +		len += scnprintf(buf + len, PAGE_SIZE - len, "%u.%06u ", q, r);
>  	}
>  	mutex_unlock(&indio_dev->mlock);
>  	buf[len - 1] = '\n';
> 

--
To unsubscribe from this list: send the line "unsubscribe linux-iio" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Input]     [Linux Kernel]     [Linux SCSI]     [X.org]

  Powered by Linux