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:
Vasileios Amoiridis 2024-10-21 21:53:10 +02:00 committed by Jonathan Cameron
parent 7adfc3484c
commit 27f8b05b2f

View File

@ -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;
} }