diff options
author | Hartmut Knaack <knaack.h@gmx.de> | 2014-12-19 17:59:25 -0500 |
---|---|---|
committer | Jonathan Cameron <jic23@kernel.org> | 2014-12-26 05:32:34 -0500 |
commit | 44cf3798a3de3ebd8e5abe6c7fd5ee5c09b049de (patch) | |
tree | 08c61eea273c85003814be6f7d6afd3c2f39cab7 /drivers/iio/pressure | |
parent | 762c4da347109398bbcc7783b7ce2496664442ed (diff) |
iio:pressure:bmp280: cleanup
The calculations for temperature and pressure compensation were already slightly
optimized in comparison to the datasheet. So, it makes sense to optimize even a
bit more, making proper use of C operators:
- variable t in bmp280_compensate_temp() can be eliminated by directly
returning the result of the relevant equation.
- make use of the += operator and eliminate an unnecessary parenthesis level in
bmp280_compensate_press().
When the initialization of the ctrl_meas register fails, the error message will
now mention the right register name.
During probe, i2c_set_clientdata() is called, although it is not necessary. Drop
it.
Signed-off-by: Hartmut Knaack <knaack.h@gmx.de>
Reviewed-by: Vlad Dogaru <vlad.dogaru@intel.com>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
Diffstat (limited to 'drivers/iio/pressure')
-rw-r--r-- | drivers/iio/pressure/bmp280.c | 16 |
1 files changed, 6 insertions, 10 deletions
diff --git a/drivers/iio/pressure/bmp280.c b/drivers/iio/pressure/bmp280.c index 47dfd347f66f..7c623e2bd633 100644 --- a/drivers/iio/pressure/bmp280.c +++ b/drivers/iio/pressure/bmp280.c | |||
@@ -148,7 +148,7 @@ static s32 bmp280_compensate_temp(struct bmp280_data *data, | |||
148 | s32 adc_temp) | 148 | s32 adc_temp) |
149 | { | 149 | { |
150 | int ret; | 150 | int ret; |
151 | s32 var1, var2, t; | 151 | s32 var1, var2; |
152 | __le16 buf[BMP280_COMP_TEMP_REG_COUNT / 2]; | 152 | __le16 buf[BMP280_COMP_TEMP_REG_COUNT / 2]; |
153 | 153 | ||
154 | ret = regmap_bulk_read(data->regmap, BMP280_REG_COMP_TEMP_START, | 154 | ret = regmap_bulk_read(data->regmap, BMP280_REG_COMP_TEMP_START, |
@@ -173,10 +173,7 @@ static s32 bmp280_compensate_temp(struct bmp280_data *data, | |||
173 | ((adc_temp >> 4) - ((s32)le16_to_cpu(buf[T1])))) >> 12) * | 173 | ((adc_temp >> 4) - ((s32)le16_to_cpu(buf[T1])))) >> 12) * |
174 | ((s32)(s16)le16_to_cpu(buf[T3]))) >> 14; | 174 | ((s32)(s16)le16_to_cpu(buf[T3]))) >> 14; |
175 | 175 | ||
176 | data->t_fine = var1 + var2; | 176 | return (data->t_fine * 5 + 128) >> 8; |
177 | t = (data->t_fine * 5 + 128) >> 8; | ||
178 | |||
179 | return t; | ||
180 | } | 177 | } |
181 | 178 | ||
182 | /* | 179 | /* |
@@ -203,8 +200,8 @@ static u32 bmp280_compensate_press(struct bmp280_data *data, | |||
203 | 200 | ||
204 | var1 = ((s64)data->t_fine) - 128000; | 201 | var1 = ((s64)data->t_fine) - 128000; |
205 | var2 = var1 * var1 * (s64)(s16)le16_to_cpu(buf[P6]); | 202 | var2 = var1 * var1 * (s64)(s16)le16_to_cpu(buf[P6]); |
206 | var2 = var2 + ((var1 * (s64)(s16)le16_to_cpu(buf[P5])) << 17); | 203 | var2 += (var1 * (s64)(s16)le16_to_cpu(buf[P5])) << 17; |
207 | var2 = var2 + (((s64)(s16)le16_to_cpu(buf[P4])) << 35); | 204 | var2 += ((s64)(s16)le16_to_cpu(buf[P4])) << 35; |
208 | var1 = ((var1 * var1 * (s64)(s16)le16_to_cpu(buf[P3])) >> 8) + | 205 | var1 = ((var1 * var1 * (s64)(s16)le16_to_cpu(buf[P3])) >> 8) + |
209 | ((var1 * (s64)(s16)le16_to_cpu(buf[P2])) << 12); | 206 | ((var1 * (s64)(s16)le16_to_cpu(buf[P2])) << 12); |
210 | var1 = ((((s64)1) << 47) + var1) * ((s64)le16_to_cpu(buf[P1])) >> 33; | 207 | var1 = ((((s64)1) << 47) + var1) * ((s64)le16_to_cpu(buf[P1])) >> 33; |
@@ -218,7 +215,7 @@ static u32 bmp280_compensate_press(struct bmp280_data *data, | |||
218 | var2 = (((s64)(s16)le16_to_cpu(buf[P8])) * p) >> 19; | 215 | var2 = (((s64)(s16)le16_to_cpu(buf[P8])) * p) >> 19; |
219 | p = ((p + var1 + var2) >> 8) + (((s64)(s16)le16_to_cpu(buf[P7])) << 4); | 216 | p = ((p + var1 + var2) >> 8) + (((s64)(s16)le16_to_cpu(buf[P7])) << 4); |
220 | 217 | ||
221 | return (u32) p; | 218 | return (u32)p; |
222 | } | 219 | } |
223 | 220 | ||
224 | static int bmp280_read_temp(struct bmp280_data *data, | 221 | static int bmp280_read_temp(struct bmp280_data *data, |
@@ -330,7 +327,7 @@ static int bmp280_chip_init(struct bmp280_data *data) | |||
330 | BMP280_MODE_NORMAL); | 327 | BMP280_MODE_NORMAL); |
331 | if (ret < 0) { | 328 | if (ret < 0) { |
332 | dev_err(&data->client->dev, | 329 | dev_err(&data->client->dev, |
333 | "failed to write config register\n"); | 330 | "failed to write ctrl_meas register\n"); |
334 | return ret; | 331 | return ret; |
335 | } | 332 | } |
336 | 333 | ||
@@ -358,7 +355,6 @@ static int bmp280_probe(struct i2c_client *client, | |||
358 | if (!indio_dev) | 355 | if (!indio_dev) |
359 | return -ENOMEM; | 356 | return -ENOMEM; |
360 | 357 | ||
361 | i2c_set_clientdata(client, indio_dev); | ||
362 | data = iio_priv(indio_dev); | 358 | data = iio_priv(indio_dev); |
363 | mutex_init(&data->lock); | 359 | mutex_init(&data->lock); |
364 | data->client = client; | 360 | data->client = client; |