mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-06 05:13:18 +00:00
iio: chemical: bme680: generalize read_*() functions
Remove the IIO specific scaling measurement units from the read functions and add them inside the ->read_raw() function to keep the read_*() generic. This way they can be used in other parts of the driver. Signed-off-by: Vasileios Amoiridis <vassilisamir@gmail.com> Link: https://patch.msgid.link/20241021195316.58911-8-vassilisamir@gmail.com Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
This commit is contained in:
parent
7adfc3484c
commit
27f8b05b2f
@ -647,23 +647,20 @@ static int bme680_gas_config(struct bme680_data *data)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int bme680_read_temp(struct bme680_data *data, int *val)
|
static int bme680_read_temp(struct bme680_data *data, s16 *comp_temp)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
u32 adc_temp;
|
u32 adc_temp;
|
||||||
s16 comp_temp;
|
|
||||||
|
|
||||||
ret = bme680_read_temp_adc(data, &adc_temp);
|
ret = bme680_read_temp_adc(data, &adc_temp);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
comp_temp = bme680_compensate_temp(data, adc_temp);
|
*comp_temp = bme680_compensate_temp(data, adc_temp);
|
||||||
*val = comp_temp * 10; /* Centidegrees to millidegrees */
|
return 0;
|
||||||
return IIO_VAL_INT;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int bme680_read_press(struct bme680_data *data,
|
static int bme680_read_press(struct bme680_data *data, u32 *comp_press)
|
||||||
int *val, int *val2)
|
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
u32 adc_press;
|
u32 adc_press;
|
||||||
@ -677,16 +674,14 @@ static int bme680_read_press(struct bme680_data *data,
|
|||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
*val = bme680_compensate_press(data, adc_press, t_fine);
|
*comp_press = bme680_compensate_press(data, adc_press, t_fine);
|
||||||
*val2 = 1000;
|
return 0;
|
||||||
return IIO_VAL_FRACTIONAL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int bme680_read_humid(struct bme680_data *data,
|
static int bme680_read_humid(struct bme680_data *data, u32 *comp_humidity)
|
||||||
int *val, int *val2)
|
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
u32 adc_humidity, comp_humidity;
|
u32 adc_humidity;
|
||||||
s32 t_fine;
|
s32 t_fine;
|
||||||
|
|
||||||
ret = bme680_get_t_fine(data, &t_fine);
|
ret = bme680_get_t_fine(data, &t_fine);
|
||||||
@ -697,15 +692,11 @@ static int bme680_read_humid(struct bme680_data *data,
|
|||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
comp_humidity = bme680_compensate_humid(data, adc_humidity, t_fine);
|
*comp_humidity = bme680_compensate_humid(data, adc_humidity, t_fine);
|
||||||
|
return 0;
|
||||||
*val = comp_humidity;
|
|
||||||
*val2 = 1000;
|
|
||||||
return IIO_VAL_FRACTIONAL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int bme680_read_gas(struct bme680_data *data,
|
static int bme680_read_gas(struct bme680_data *data, int *comp_gas_res)
|
||||||
int *val)
|
|
||||||
{
|
{
|
||||||
struct device *dev = regmap_get_device(data->regmap);
|
struct device *dev = regmap_get_device(data->regmap);
|
||||||
int ret;
|
int ret;
|
||||||
@ -740,9 +731,8 @@ static int bme680_read_gas(struct bme680_data *data,
|
|||||||
}
|
}
|
||||||
|
|
||||||
gas_range = FIELD_GET(BME680_GAS_RANGE_MASK, gas_regs_val);
|
gas_range = FIELD_GET(BME680_GAS_RANGE_MASK, gas_regs_val);
|
||||||
|
*comp_gas_res = bme680_compensate_gas(data, adc_gas_res, gas_range);
|
||||||
*val = bme680_compensate_gas(data, adc_gas_res, gas_range);
|
return 0;
|
||||||
return IIO_VAL_INT;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int bme680_read_raw(struct iio_dev *indio_dev,
|
static int bme680_read_raw(struct iio_dev *indio_dev,
|
||||||
@ -750,7 +740,7 @@ static int bme680_read_raw(struct iio_dev *indio_dev,
|
|||||||
int *val, int *val2, long mask)
|
int *val, int *val2, long mask)
|
||||||
{
|
{
|
||||||
struct bme680_data *data = iio_priv(indio_dev);
|
struct bme680_data *data = iio_priv(indio_dev);
|
||||||
int ret;
|
int chan_val, ret;
|
||||||
|
|
||||||
guard(mutex)(&data->lock);
|
guard(mutex)(&data->lock);
|
||||||
|
|
||||||
@ -767,13 +757,35 @@ static int bme680_read_raw(struct iio_dev *indio_dev,
|
|||||||
case IIO_CHAN_INFO_PROCESSED:
|
case IIO_CHAN_INFO_PROCESSED:
|
||||||
switch (chan->type) {
|
switch (chan->type) {
|
||||||
case IIO_TEMP:
|
case IIO_TEMP:
|
||||||
return bme680_read_temp(data, val);
|
ret = bme680_read_temp(data, (s16 *)&chan_val);
|
||||||
|
if (ret)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
*val = chan_val * 10;
|
||||||
|
return IIO_VAL_INT;
|
||||||
case IIO_PRESSURE:
|
case IIO_PRESSURE:
|
||||||
return bme680_read_press(data, val, val2);
|
ret = bme680_read_press(data, &chan_val);
|
||||||
|
if (ret)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
*val = chan_val;
|
||||||
|
*val2 = 1000;
|
||||||
|
return IIO_VAL_FRACTIONAL;
|
||||||
case IIO_HUMIDITYRELATIVE:
|
case IIO_HUMIDITYRELATIVE:
|
||||||
return bme680_read_humid(data, val, val2);
|
ret = bme680_read_humid(data, &chan_val);
|
||||||
|
if (ret)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
*val = chan_val;
|
||||||
|
*val2 = 1000;
|
||||||
|
return IIO_VAL_FRACTIONAL;
|
||||||
case IIO_RESISTANCE:
|
case IIO_RESISTANCE:
|
||||||
return bme680_read_gas(data, val);
|
ret = bme680_read_gas(data, &chan_val);
|
||||||
|
if (ret)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
*val = chan_val;
|
||||||
|
return IIO_VAL_INT;
|
||||||
default:
|
default:
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user