Merge tag 'trace-printf-v6.13' of git://git.kernel.org/pub/scm/linux/kernel/git/trace...
[drm/drm-misc.git] / drivers / iio / pressure / bmp280-core.c
blobe5ec8137961fcbbb54a6d277d8de1cf474aebc1d
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3 * Copyright (c) 2010 Christoph Mair <christoph.mair@gmail.com>
4 * Copyright (c) 2012 Bosch Sensortec GmbH
5 * Copyright (c) 2012 Unixphere AB
6 * Copyright (c) 2014 Intel Corporation
7 * Copyright (c) 2016 Linus Walleij <linus.walleij@linaro.org>
9 * Driver for Bosch Sensortec BMP180 and BMP280 digital pressure sensor.
11 * Datasheet:
12 * https://cdn-shop.adafruit.com/datasheets/BST-BMP180-DS000-09.pdf
13 * https://www.bosch-sensortec.com/media/boschsensortec/downloads/datasheets/bst-bmp280-ds001.pdf
14 * https://www.bosch-sensortec.com/media/boschsensortec/downloads/datasheets/bst-bme280-ds002.pdf
15 * https://www.bosch-sensortec.com/media/boschsensortec/downloads/datasheets/bst-bmp388-ds001.pdf
16 * https://www.bosch-sensortec.com/media/boschsensortec/downloads/datasheets/bst-bmp390-ds002.pdf
17 * https://www.bosch-sensortec.com/media/boschsensortec/downloads/datasheets/bst-bmp581-ds004.pdf
19 * Sensor API:
20 * https://github.com/boschsensortec/BME280_SensorAPI
21 * https://github.com/boschsensortec/BMP3_SensorAPI
22 * https://github.com/boschsensortec/BMP5_SensorAPI
24 * Notice:
25 * The link to the bmp180 datasheet points to an outdated version missing these changes:
26 * - Changed document referral from ANP015 to BST-MPS-AN004-00 on page 26
27 * - Updated equation for B3 param on section 3.5 to ((((long)AC1 * 4 + X3) << oss) + 2) / 4
28 * - Updated RoHS directive to 2011/65/EU effective 8 June 2011 on page 26
31 #define pr_fmt(fmt) "bmp280: " fmt
33 #include <linux/bitops.h>
34 #include <linux/bitfield.h>
35 #include <linux/cleanup.h>
36 #include <linux/completion.h>
37 #include <linux/delay.h>
38 #include <linux/device.h>
39 #include <linux/gpio/consumer.h>
40 #include <linux/interrupt.h>
41 #include <linux/irq.h> /* For irq_get_irq_data() */
42 #include <linux/module.h>
43 #include <linux/nvmem-provider.h>
44 #include <linux/pm_runtime.h>
45 #include <linux/property.h>
46 #include <linux/random.h>
47 #include <linux/regmap.h>
48 #include <linux/regulator/consumer.h>
50 #include <linux/iio/buffer.h>
51 #include <linux/iio/iio.h>
52 #include <linux/iio/trigger.h>
53 #include <linux/iio/trigger_consumer.h>
54 #include <linux/iio/triggered_buffer.h>
56 #include <linux/unaligned.h>
58 #include "bmp280.h"
61 * These enums are used for indexing into the array of calibration
62 * coefficients for BMP180.
64 enum { AC1, AC2, AC3, AC4, AC5, AC6, B1, B2, MB, MC, MD };
66 enum bmp380_odr {
67 BMP380_ODR_200HZ,
68 BMP380_ODR_100HZ,
69 BMP380_ODR_50HZ,
70 BMP380_ODR_25HZ,
71 BMP380_ODR_12_5HZ,
72 BMP380_ODR_6_25HZ,
73 BMP380_ODR_3_125HZ,
74 BMP380_ODR_1_5625HZ,
75 BMP380_ODR_0_78HZ,
76 BMP380_ODR_0_39HZ,
77 BMP380_ODR_0_2HZ,
78 BMP380_ODR_0_1HZ,
79 BMP380_ODR_0_05HZ,
80 BMP380_ODR_0_02HZ,
81 BMP380_ODR_0_01HZ,
82 BMP380_ODR_0_006HZ,
83 BMP380_ODR_0_003HZ,
84 BMP380_ODR_0_0015HZ,
87 enum bmp580_odr {
88 BMP580_ODR_240HZ,
89 BMP580_ODR_218HZ,
90 BMP580_ODR_199HZ,
91 BMP580_ODR_179HZ,
92 BMP580_ODR_160HZ,
93 BMP580_ODR_149HZ,
94 BMP580_ODR_140HZ,
95 BMP580_ODR_129HZ,
96 BMP580_ODR_120HZ,
97 BMP580_ODR_110HZ,
98 BMP580_ODR_100HZ,
99 BMP580_ODR_89HZ,
100 BMP580_ODR_80HZ,
101 BMP580_ODR_70HZ,
102 BMP580_ODR_60HZ,
103 BMP580_ODR_50HZ,
104 BMP580_ODR_45HZ,
105 BMP580_ODR_40HZ,
106 BMP580_ODR_35HZ,
107 BMP580_ODR_30HZ,
108 BMP580_ODR_25HZ,
109 BMP580_ODR_20HZ,
110 BMP580_ODR_15HZ,
111 BMP580_ODR_10HZ,
112 BMP580_ODR_5HZ,
113 BMP580_ODR_4HZ,
114 BMP580_ODR_3HZ,
115 BMP580_ODR_2HZ,
116 BMP580_ODR_1HZ,
117 BMP580_ODR_0_5HZ,
118 BMP580_ODR_0_25HZ,
119 BMP580_ODR_0_125HZ,
123 * These enums are used for indexing into the array of compensation
124 * parameters for BMP280.
126 enum { T1, T2, T3, P1, P2, P3, P4, P5, P6, P7, P8, P9 };
128 enum {
129 /* Temperature calib indexes */
130 BMP380_T1 = 0,
131 BMP380_T2 = 2,
132 BMP380_T3 = 4,
133 /* Pressure calib indexes */
134 BMP380_P1 = 5,
135 BMP380_P2 = 7,
136 BMP380_P3 = 9,
137 BMP380_P4 = 10,
138 BMP380_P5 = 11,
139 BMP380_P6 = 13,
140 BMP380_P7 = 15,
141 BMP380_P8 = 16,
142 BMP380_P9 = 17,
143 BMP380_P10 = 19,
144 BMP380_P11 = 20,
147 enum bmp280_scan {
148 BMP280_PRESS,
149 BMP280_TEMP,
150 BME280_HUMID,
153 static const struct iio_chan_spec bmp280_channels[] = {
155 .type = IIO_PRESSURE,
156 /* PROCESSED maintained for ABI backwards compatibility */
157 .info_mask_separate = BIT(IIO_CHAN_INFO_PROCESSED) |
158 BIT(IIO_CHAN_INFO_RAW) |
159 BIT(IIO_CHAN_INFO_SCALE) |
160 BIT(IIO_CHAN_INFO_OVERSAMPLING_RATIO),
161 .scan_index = 0,
162 .scan_type = {
163 .sign = 'u',
164 .realbits = 32,
165 .storagebits = 32,
166 .endianness = IIO_CPU,
170 .type = IIO_TEMP,
171 /* PROCESSED maintained for ABI backwards compatibility */
172 .info_mask_separate = BIT(IIO_CHAN_INFO_PROCESSED) |
173 BIT(IIO_CHAN_INFO_RAW) |
174 BIT(IIO_CHAN_INFO_SCALE) |
175 BIT(IIO_CHAN_INFO_OVERSAMPLING_RATIO),
176 .scan_index = 1,
177 .scan_type = {
178 .sign = 's',
179 .realbits = 32,
180 .storagebits = 32,
181 .endianness = IIO_CPU,
184 IIO_CHAN_SOFT_TIMESTAMP(2),
187 static const struct iio_chan_spec bme280_channels[] = {
189 .type = IIO_PRESSURE,
190 /* PROCESSED maintained for ABI backwards compatibility */
191 .info_mask_separate = BIT(IIO_CHAN_INFO_PROCESSED) |
192 BIT(IIO_CHAN_INFO_RAW) |
193 BIT(IIO_CHAN_INFO_SCALE) |
194 BIT(IIO_CHAN_INFO_OVERSAMPLING_RATIO),
195 .scan_index = 0,
196 .scan_type = {
197 .sign = 'u',
198 .realbits = 32,
199 .storagebits = 32,
200 .endianness = IIO_CPU,
204 .type = IIO_TEMP,
205 /* PROCESSED maintained for ABI backwards compatibility */
206 .info_mask_separate = BIT(IIO_CHAN_INFO_PROCESSED) |
207 BIT(IIO_CHAN_INFO_RAW) |
208 BIT(IIO_CHAN_INFO_SCALE) |
209 BIT(IIO_CHAN_INFO_OVERSAMPLING_RATIO),
210 .scan_index = 1,
211 .scan_type = {
212 .sign = 's',
213 .realbits = 32,
214 .storagebits = 32,
215 .endianness = IIO_CPU,
219 .type = IIO_HUMIDITYRELATIVE,
220 /* PROCESSED maintained for ABI backwards compatibility */
221 .info_mask_separate = BIT(IIO_CHAN_INFO_PROCESSED) |
222 BIT(IIO_CHAN_INFO_RAW) |
223 BIT(IIO_CHAN_INFO_SCALE) |
224 BIT(IIO_CHAN_INFO_OVERSAMPLING_RATIO),
225 .scan_index = 2,
226 .scan_type = {
227 .sign = 'u',
228 .realbits = 32,
229 .storagebits = 32,
230 .endianness = IIO_CPU,
233 IIO_CHAN_SOFT_TIMESTAMP(3),
236 static const struct iio_chan_spec bmp380_channels[] = {
238 .type = IIO_PRESSURE,
239 /* PROCESSED maintained for ABI backwards compatibility */
240 .info_mask_separate = BIT(IIO_CHAN_INFO_PROCESSED) |
241 BIT(IIO_CHAN_INFO_RAW) |
242 BIT(IIO_CHAN_INFO_SCALE) |
243 BIT(IIO_CHAN_INFO_OVERSAMPLING_RATIO),
244 .info_mask_shared_by_all = BIT(IIO_CHAN_INFO_SAMP_FREQ) |
245 BIT(IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY),
246 .scan_index = 0,
247 .scan_type = {
248 .sign = 'u',
249 .realbits = 32,
250 .storagebits = 32,
251 .endianness = IIO_CPU,
255 .type = IIO_TEMP,
256 /* PROCESSED maintained for ABI backwards compatibility */
257 .info_mask_separate = BIT(IIO_CHAN_INFO_PROCESSED) |
258 BIT(IIO_CHAN_INFO_RAW) |
259 BIT(IIO_CHAN_INFO_SCALE) |
260 BIT(IIO_CHAN_INFO_OVERSAMPLING_RATIO),
261 .info_mask_shared_by_all = BIT(IIO_CHAN_INFO_SAMP_FREQ) |
262 BIT(IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY),
263 .scan_index = 1,
264 .scan_type = {
265 .sign = 's',
266 .realbits = 32,
267 .storagebits = 32,
268 .endianness = IIO_CPU,
271 IIO_CHAN_SOFT_TIMESTAMP(2),
274 static const struct iio_chan_spec bmp580_channels[] = {
276 .type = IIO_PRESSURE,
277 /* PROCESSED maintained for ABI backwards compatibility */
278 .info_mask_separate = BIT(IIO_CHAN_INFO_PROCESSED) |
279 BIT(IIO_CHAN_INFO_RAW) |
280 BIT(IIO_CHAN_INFO_SCALE) |
281 BIT(IIO_CHAN_INFO_OVERSAMPLING_RATIO),
282 .info_mask_shared_by_all = BIT(IIO_CHAN_INFO_SAMP_FREQ) |
283 BIT(IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY),
284 .scan_index = 0,
285 .scan_type = {
286 .sign = 'u',
287 .realbits = 24,
288 .storagebits = 32,
289 .endianness = IIO_LE,
293 .type = IIO_TEMP,
294 /* PROCESSED maintained for ABI backwards compatibility */
295 .info_mask_separate = BIT(IIO_CHAN_INFO_PROCESSED) |
296 BIT(IIO_CHAN_INFO_RAW) |
297 BIT(IIO_CHAN_INFO_SCALE) |
298 BIT(IIO_CHAN_INFO_OVERSAMPLING_RATIO),
299 .info_mask_shared_by_all = BIT(IIO_CHAN_INFO_SAMP_FREQ) |
300 BIT(IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY),
301 .scan_index = 1,
302 .scan_type = {
303 .sign = 's',
304 .realbits = 24,
305 .storagebits = 32,
306 .endianness = IIO_LE,
309 IIO_CHAN_SOFT_TIMESTAMP(2),
312 static int bmp280_read_calib(struct bmp280_data *data)
314 struct bmp280_calib *calib = &data->calib.bmp280;
315 int ret;
317 /* Read temperature and pressure calibration values. */
318 ret = regmap_bulk_read(data->regmap, BMP280_REG_COMP_TEMP_START,
319 data->bmp280_cal_buf,
320 sizeof(data->bmp280_cal_buf));
321 if (ret) {
322 dev_err(data->dev,
323 "failed to read calibration parameters\n");
324 return ret;
327 /* Toss calibration data into the entropy pool */
328 add_device_randomness(data->bmp280_cal_buf,
329 sizeof(data->bmp280_cal_buf));
331 /* Parse temperature calibration values. */
332 calib->T1 = le16_to_cpu(data->bmp280_cal_buf[T1]);
333 calib->T2 = le16_to_cpu(data->bmp280_cal_buf[T2]);
334 calib->T3 = le16_to_cpu(data->bmp280_cal_buf[T3]);
336 /* Parse pressure calibration values. */
337 calib->P1 = le16_to_cpu(data->bmp280_cal_buf[P1]);
338 calib->P2 = le16_to_cpu(data->bmp280_cal_buf[P2]);
339 calib->P3 = le16_to_cpu(data->bmp280_cal_buf[P3]);
340 calib->P4 = le16_to_cpu(data->bmp280_cal_buf[P4]);
341 calib->P5 = le16_to_cpu(data->bmp280_cal_buf[P5]);
342 calib->P6 = le16_to_cpu(data->bmp280_cal_buf[P6]);
343 calib->P7 = le16_to_cpu(data->bmp280_cal_buf[P7]);
344 calib->P8 = le16_to_cpu(data->bmp280_cal_buf[P8]);
345 calib->P9 = le16_to_cpu(data->bmp280_cal_buf[P9]);
347 return 0;
351 * These enums are used for indexing into the array of humidity parameters
352 * for BME280. Due to some weird indexing, unaligned BE/LE accesses co-exist in
353 * order to prepare the FIELD_{GET/PREP}() fields. Table 16 in Section 4.2.2 of
354 * the datasheet.
356 enum { H2 = 0, H3 = 2, H4 = 3, H5 = 4, H6 = 6 };
358 static int bme280_read_calib(struct bmp280_data *data)
360 struct bmp280_calib *calib = &data->calib.bmp280;
361 struct device *dev = data->dev;
362 s16 h4_upper, h4_lower, tmp_1, tmp_2, tmp_3;
363 unsigned int tmp;
364 int ret;
366 /* Load shared calibration params with bmp280 first */
367 ret = bmp280_read_calib(data);
368 if (ret)
369 return ret;
371 ret = regmap_read(data->regmap, BME280_REG_COMP_H1, &tmp);
372 if (ret) {
373 dev_err(dev, "failed to read H1 comp value\n");
374 return ret;
376 calib->H1 = tmp;
378 ret = regmap_bulk_read(data->regmap, BME280_REG_COMP_H2,
379 data->bme280_humid_cal_buf,
380 sizeof(data->bme280_humid_cal_buf));
381 if (ret) {
382 dev_err(dev, "failed to read humidity calibration values\n");
383 return ret;
386 calib->H2 = get_unaligned_le16(&data->bme280_humid_cal_buf[H2]);
387 calib->H3 = data->bme280_humid_cal_buf[H3];
388 tmp_1 = get_unaligned_be16(&data->bme280_humid_cal_buf[H4]);
389 tmp_2 = FIELD_GET(BME280_COMP_H4_GET_MASK_UP, tmp_1);
390 h4_upper = FIELD_PREP(BME280_COMP_H4_PREP_MASK_UP, tmp_2);
391 h4_lower = FIELD_GET(BME280_COMP_H4_MASK_LOW, tmp_1);
392 calib->H4 = sign_extend32(h4_upper | h4_lower, 11);
393 tmp_3 = get_unaligned_le16(&data->bme280_humid_cal_buf[H5]);
394 calib->H5 = sign_extend32(FIELD_GET(BME280_COMP_H5_MASK, tmp_3), 11);
395 calib->H6 = data->bme280_humid_cal_buf[H6];
397 return 0;
400 static int bme280_read_humid_adc(struct bmp280_data *data, u16 *adc_humidity)
402 u16 value_humidity;
403 int ret;
405 ret = regmap_bulk_read(data->regmap, BME280_REG_HUMIDITY_MSB,
406 &data->be16, BME280_NUM_HUMIDITY_BYTES);
407 if (ret) {
408 dev_err(data->dev, "failed to read humidity\n");
409 return ret;
412 value_humidity = be16_to_cpu(data->be16);
413 if (value_humidity == BMP280_HUMIDITY_SKIPPED) {
414 dev_err(data->dev, "reading humidity skipped\n");
415 return -EIO;
417 *adc_humidity = value_humidity;
419 return 0;
423 * Returns humidity in percent, resolution is 0.01 percent. Output value of
424 * "47445" represents 47445/1024 = 46.333 %RH.
426 * Taken from BME280 datasheet, Section 4.2.3, "Compensation formula".
428 static u32 bme280_compensate_humidity(struct bmp280_data *data,
429 u16 adc_humidity, s32 t_fine)
431 struct bmp280_calib *calib = &data->calib.bmp280;
432 s32 var;
434 var = t_fine - (s32)76800;
435 var = (((((s32)adc_humidity << 14) - (calib->H4 << 20) - (calib->H5 * var))
436 + (s32)16384) >> 15) * (((((((var * calib->H6) >> 10)
437 * (((var * (s32)calib->H3) >> 11) + (s32)32768)) >> 10)
438 + (s32)2097152) * calib->H2 + 8192) >> 14);
439 var -= ((((var >> 15) * (var >> 15)) >> 7) * (s32)calib->H1) >> 4;
441 var = clamp_val(var, 0, 419430400);
443 return var >> 12;
446 static int bmp280_read_temp_adc(struct bmp280_data *data, u32 *adc_temp)
448 u32 value_temp;
449 int ret;
451 ret = regmap_bulk_read(data->regmap, BMP280_REG_TEMP_MSB,
452 data->buf, BMP280_NUM_TEMP_BYTES);
453 if (ret) {
454 dev_err(data->dev, "failed to read temperature\n");
455 return ret;
458 value_temp = FIELD_GET(BMP280_MEAS_TRIM_MASK, get_unaligned_be24(data->buf));
459 if (value_temp == BMP280_TEMP_SKIPPED) {
460 dev_err(data->dev, "reading temperature skipped\n");
461 return -EIO;
463 *adc_temp = value_temp;
465 return 0;
469 * Returns temperature in DegC, resolution is 0.01 DegC. Output value of
470 * "5123" equals 51.23 DegC. t_fine carries fine temperature as global
471 * value.
473 * Taken from datasheet, Section 3.11.3, "Compensation formula".
475 static s32 bmp280_calc_t_fine(struct bmp280_data *data, u32 adc_temp)
477 struct bmp280_calib *calib = &data->calib.bmp280;
478 s32 var1, var2;
480 var1 = (((((s32)adc_temp) >> 3) - ((s32)calib->T1 << 1)) *
481 ((s32)calib->T2)) >> 11;
482 var2 = (((((((s32)adc_temp) >> 4) - ((s32)calib->T1)) *
483 ((((s32)adc_temp >> 4) - ((s32)calib->T1))) >> 12) *
484 ((s32)calib->T3))) >> 14;
485 return var1 + var2; /* t_fine = var1 + var2 */
488 static int bmp280_get_t_fine(struct bmp280_data *data, s32 *t_fine)
490 u32 adc_temp;
491 int ret;
493 ret = bmp280_read_temp_adc(data, &adc_temp);
494 if (ret)
495 return ret;
497 *t_fine = bmp280_calc_t_fine(data, adc_temp);
499 return 0;
502 static s32 bmp280_compensate_temp(struct bmp280_data *data, u32 adc_temp)
504 return (bmp280_calc_t_fine(data, adc_temp) * 5 + 128) / 256;
507 static int bmp280_read_press_adc(struct bmp280_data *data, u32 *adc_press)
509 u32 value_press;
510 int ret;
512 ret = regmap_bulk_read(data->regmap, BMP280_REG_PRESS_MSB,
513 data->buf, BMP280_NUM_PRESS_BYTES);
514 if (ret) {
515 dev_err(data->dev, "failed to read pressure\n");
516 return ret;
519 value_press = FIELD_GET(BMP280_MEAS_TRIM_MASK, get_unaligned_be24(data->buf));
520 if (value_press == BMP280_PRESS_SKIPPED) {
521 dev_err(data->dev, "reading pressure skipped\n");
522 return -EIO;
524 *adc_press = value_press;
526 return 0;
530 * Returns pressure in Pa as unsigned 32 bit integer in Q24.8 format (24
531 * integer bits and 8 fractional bits). Output value of "24674867"
532 * represents 24674867/256 = 96386.2 Pa = 963.862 hPa
534 * Taken from datasheet, Section 3.11.3, "Compensation formula".
536 static u32 bmp280_compensate_press(struct bmp280_data *data,
537 u32 adc_press, s32 t_fine)
539 struct bmp280_calib *calib = &data->calib.bmp280;
540 s64 var1, var2, p;
542 var1 = ((s64)t_fine) - 128000;
543 var2 = var1 * var1 * (s64)calib->P6;
544 var2 += (var1 * (s64)calib->P5) << 17;
545 var2 += ((s64)calib->P4) << 35;
546 var1 = ((var1 * var1 * (s64)calib->P3) >> 8) +
547 ((var1 * (s64)calib->P2) << 12);
548 var1 = ((((s64)1) << 47) + var1) * ((s64)calib->P1) >> 33;
550 if (var1 == 0)
551 return 0;
553 p = ((((s64)1048576 - (s32)adc_press) << 31) - var2) * 3125;
554 p = div64_s64(p, var1);
555 var1 = (((s64)calib->P9) * (p >> 13) * (p >> 13)) >> 25;
556 var2 = ((s64)(calib->P8) * p) >> 19;
557 p = ((p + var1 + var2) >> 8) + (((s64)calib->P7) << 4);
559 return (u32)p;
562 static int bmp280_read_temp(struct bmp280_data *data, s32 *comp_temp)
564 u32 adc_temp;
565 int ret;
567 ret = bmp280_read_temp_adc(data, &adc_temp);
568 if (ret)
569 return ret;
571 *comp_temp = bmp280_compensate_temp(data, adc_temp);
573 return 0;
576 static int bmp280_read_press(struct bmp280_data *data, u32 *comp_press)
578 u32 adc_press;
579 s32 t_fine;
580 int ret;
582 ret = bmp280_get_t_fine(data, &t_fine);
583 if (ret)
584 return ret;
586 ret = bmp280_read_press_adc(data, &adc_press);
587 if (ret)
588 return ret;
590 *comp_press = bmp280_compensate_press(data, adc_press, t_fine);
592 return 0;
595 static int bme280_read_humid(struct bmp280_data *data, u32 *comp_humidity)
597 u16 adc_humidity;
598 s32 t_fine;
599 int ret;
601 ret = bmp280_get_t_fine(data, &t_fine);
602 if (ret)
603 return ret;
605 ret = bme280_read_humid_adc(data, &adc_humidity);
606 if (ret)
607 return ret;
609 *comp_humidity = bme280_compensate_humidity(data, adc_humidity, t_fine);
611 return 0;
614 static int bmp280_read_raw_impl(struct iio_dev *indio_dev,
615 struct iio_chan_spec const *chan,
616 int *val, int *val2, long mask)
618 struct bmp280_data *data = iio_priv(indio_dev);
619 int chan_value;
620 int ret;
622 guard(mutex)(&data->lock);
624 switch (mask) {
625 case IIO_CHAN_INFO_PROCESSED:
626 ret = data->chip_info->set_mode(data, BMP280_FORCED);
627 if (ret)
628 return ret;
630 ret = data->chip_info->wait_conv(data);
631 if (ret)
632 return ret;
634 switch (chan->type) {
635 case IIO_HUMIDITYRELATIVE:
636 ret = data->chip_info->read_humid(data, &chan_value);
637 if (ret)
638 return ret;
640 *val = data->chip_info->humid_coeffs[0] * chan_value;
641 *val2 = data->chip_info->humid_coeffs[1];
642 return data->chip_info->humid_coeffs_type;
643 case IIO_PRESSURE:
644 ret = data->chip_info->read_press(data, &chan_value);
645 if (ret)
646 return ret;
648 *val = data->chip_info->press_coeffs[0] * chan_value;
649 *val2 = data->chip_info->press_coeffs[1];
650 return data->chip_info->press_coeffs_type;
651 case IIO_TEMP:
652 ret = data->chip_info->read_temp(data, &chan_value);
653 if (ret)
654 return ret;
656 *val = data->chip_info->temp_coeffs[0] * chan_value;
657 *val2 = data->chip_info->temp_coeffs[1];
658 return data->chip_info->temp_coeffs_type;
659 default:
660 return -EINVAL;
662 case IIO_CHAN_INFO_RAW:
663 ret = data->chip_info->set_mode(data, BMP280_FORCED);
664 if (ret)
665 return ret;
667 ret = data->chip_info->wait_conv(data);
668 if (ret)
669 return ret;
671 switch (chan->type) {
672 case IIO_HUMIDITYRELATIVE:
673 ret = data->chip_info->read_humid(data, &chan_value);
674 if (ret)
675 return ret;
677 *val = chan_value;
678 return IIO_VAL_INT;
679 case IIO_PRESSURE:
680 ret = data->chip_info->read_press(data, &chan_value);
681 if (ret)
682 return ret;
684 *val = chan_value;
685 return IIO_VAL_INT;
686 case IIO_TEMP:
687 ret = data->chip_info->read_temp(data, &chan_value);
688 if (ret)
689 return ret;
691 *val = chan_value;
692 return IIO_VAL_INT;
693 default:
694 return -EINVAL;
696 case IIO_CHAN_INFO_SCALE:
697 switch (chan->type) {
698 case IIO_HUMIDITYRELATIVE:
699 *val = data->chip_info->humid_coeffs[0];
700 *val2 = data->chip_info->humid_coeffs[1];
701 return data->chip_info->humid_coeffs_type;
702 case IIO_PRESSURE:
703 *val = data->chip_info->press_coeffs[0];
704 *val2 = data->chip_info->press_coeffs[1];
705 return data->chip_info->press_coeffs_type;
706 case IIO_TEMP:
707 *val = data->chip_info->temp_coeffs[0];
708 *val2 = data->chip_info->temp_coeffs[1];
709 return data->chip_info->temp_coeffs_type;
710 default:
711 return -EINVAL;
713 case IIO_CHAN_INFO_OVERSAMPLING_RATIO:
714 switch (chan->type) {
715 case IIO_HUMIDITYRELATIVE:
716 *val = 1 << data->oversampling_humid;
717 return IIO_VAL_INT;
718 case IIO_PRESSURE:
719 *val = 1 << data->oversampling_press;
720 return IIO_VAL_INT;
721 case IIO_TEMP:
722 *val = 1 << data->oversampling_temp;
723 return IIO_VAL_INT;
724 default:
725 return -EINVAL;
727 case IIO_CHAN_INFO_SAMP_FREQ:
728 if (!data->chip_info->sampling_freq_avail)
729 return -EINVAL;
731 *val = data->chip_info->sampling_freq_avail[data->sampling_freq][0];
732 *val2 = data->chip_info->sampling_freq_avail[data->sampling_freq][1];
733 return IIO_VAL_INT_PLUS_MICRO;
734 case IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY:
735 if (!data->chip_info->iir_filter_coeffs_avail)
736 return -EINVAL;
738 *val = (1 << data->iir_filter_coeff) - 1;
739 return IIO_VAL_INT;
740 default:
741 return -EINVAL;
745 static int bmp280_read_raw(struct iio_dev *indio_dev,
746 struct iio_chan_spec const *chan,
747 int *val, int *val2, long mask)
749 struct bmp280_data *data = iio_priv(indio_dev);
750 int ret;
752 pm_runtime_get_sync(data->dev);
753 ret = bmp280_read_raw_impl(indio_dev, chan, val, val2, mask);
754 pm_runtime_mark_last_busy(data->dev);
755 pm_runtime_put_autosuspend(data->dev);
757 return ret;
760 static int bme280_write_oversampling_ratio_humid(struct bmp280_data *data,
761 int val)
763 const int *avail = data->chip_info->oversampling_humid_avail;
764 const int n = data->chip_info->num_oversampling_humid_avail;
765 int ret, prev;
766 int i;
768 for (i = 0; i < n; i++) {
769 if (avail[i] == val) {
770 prev = data->oversampling_humid;
771 data->oversampling_humid = ilog2(val);
773 ret = data->chip_info->chip_config(data);
774 if (ret) {
775 data->oversampling_humid = prev;
776 data->chip_info->chip_config(data);
777 return ret;
779 return 0;
782 return -EINVAL;
785 static int bmp280_write_oversampling_ratio_temp(struct bmp280_data *data,
786 int val)
788 const int *avail = data->chip_info->oversampling_temp_avail;
789 const int n = data->chip_info->num_oversampling_temp_avail;
790 int ret, prev;
791 int i;
793 for (i = 0; i < n; i++) {
794 if (avail[i] == val) {
795 prev = data->oversampling_temp;
796 data->oversampling_temp = ilog2(val);
798 ret = data->chip_info->chip_config(data);
799 if (ret) {
800 data->oversampling_temp = prev;
801 data->chip_info->chip_config(data);
802 return ret;
804 return 0;
807 return -EINVAL;
810 static int bmp280_write_oversampling_ratio_press(struct bmp280_data *data,
811 int val)
813 const int *avail = data->chip_info->oversampling_press_avail;
814 const int n = data->chip_info->num_oversampling_press_avail;
815 int ret, prev;
816 int i;
818 for (i = 0; i < n; i++) {
819 if (avail[i] == val) {
820 prev = data->oversampling_press;
821 data->oversampling_press = ilog2(val);
823 ret = data->chip_info->chip_config(data);
824 if (ret) {
825 data->oversampling_press = prev;
826 data->chip_info->chip_config(data);
827 return ret;
829 return 0;
832 return -EINVAL;
835 static int bmp280_write_sampling_frequency(struct bmp280_data *data,
836 int val, int val2)
838 const int (*avail)[2] = data->chip_info->sampling_freq_avail;
839 const int n = data->chip_info->num_sampling_freq_avail;
840 int ret, prev;
841 int i;
843 for (i = 0; i < n; i++) {
844 if (avail[i][0] == val && avail[i][1] == val2) {
845 prev = data->sampling_freq;
846 data->sampling_freq = i;
848 ret = data->chip_info->chip_config(data);
849 if (ret) {
850 data->sampling_freq = prev;
851 data->chip_info->chip_config(data);
852 return ret;
854 return 0;
857 return -EINVAL;
860 static int bmp280_write_iir_filter_coeffs(struct bmp280_data *data, int val)
862 const int *avail = data->chip_info->iir_filter_coeffs_avail;
863 const int n = data->chip_info->num_iir_filter_coeffs_avail;
864 int ret, prev;
865 int i;
867 for (i = 0; i < n; i++) {
868 if (avail[i] - 1 == val) {
869 prev = data->iir_filter_coeff;
870 data->iir_filter_coeff = i;
872 ret = data->chip_info->chip_config(data);
873 if (ret) {
874 data->iir_filter_coeff = prev;
875 data->chip_info->chip_config(data);
876 return ret;
879 return 0;
882 return -EINVAL;
885 static int bmp280_write_raw_impl(struct iio_dev *indio_dev,
886 struct iio_chan_spec const *chan,
887 int val, int val2, long mask)
889 struct bmp280_data *data = iio_priv(indio_dev);
891 guard(mutex)(&data->lock);
894 * Helper functions to update sensor running configuration.
895 * If an error happens applying new settings, will try restore
896 * previous parameters to ensure the sensor is left in a known
897 * working configuration.
899 switch (mask) {
900 case IIO_CHAN_INFO_OVERSAMPLING_RATIO:
901 switch (chan->type) {
902 case IIO_HUMIDITYRELATIVE:
903 return bme280_write_oversampling_ratio_humid(data, val);
904 case IIO_PRESSURE:
905 return bmp280_write_oversampling_ratio_press(data, val);
906 case IIO_TEMP:
907 return bmp280_write_oversampling_ratio_temp(data, val);
908 default:
909 return -EINVAL;
911 case IIO_CHAN_INFO_SAMP_FREQ:
912 return bmp280_write_sampling_frequency(data, val, val2);
913 case IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY:
914 return bmp280_write_iir_filter_coeffs(data, val);
915 default:
916 return -EINVAL;
920 static int bmp280_write_raw(struct iio_dev *indio_dev,
921 struct iio_chan_spec const *chan,
922 int val, int val2, long mask)
924 struct bmp280_data *data = iio_priv(indio_dev);
925 int ret;
927 pm_runtime_get_sync(data->dev);
928 ret = bmp280_write_raw_impl(indio_dev, chan, val, val2, mask);
929 pm_runtime_mark_last_busy(data->dev);
930 pm_runtime_put_autosuspend(data->dev);
932 return ret;
935 static int bmp280_read_avail(struct iio_dev *indio_dev,
936 struct iio_chan_spec const *chan,
937 const int **vals, int *type, int *length,
938 long mask)
940 struct bmp280_data *data = iio_priv(indio_dev);
942 switch (mask) {
943 case IIO_CHAN_INFO_OVERSAMPLING_RATIO:
944 switch (chan->type) {
945 case IIO_PRESSURE:
946 *vals = data->chip_info->oversampling_press_avail;
947 *length = data->chip_info->num_oversampling_press_avail;
948 break;
949 case IIO_TEMP:
950 *vals = data->chip_info->oversampling_temp_avail;
951 *length = data->chip_info->num_oversampling_temp_avail;
952 break;
953 default:
954 return -EINVAL;
956 *type = IIO_VAL_INT;
957 return IIO_AVAIL_LIST;
958 case IIO_CHAN_INFO_SAMP_FREQ:
959 *vals = (const int *)data->chip_info->sampling_freq_avail;
960 *type = IIO_VAL_INT_PLUS_MICRO;
961 /* Values are stored in a 2D matrix */
962 *length = data->chip_info->num_sampling_freq_avail;
963 return IIO_AVAIL_LIST;
964 case IIO_CHAN_INFO_LOW_PASS_FILTER_3DB_FREQUENCY:
965 *vals = data->chip_info->iir_filter_coeffs_avail;
966 *type = IIO_VAL_INT;
967 *length = data->chip_info->num_iir_filter_coeffs_avail;
968 return IIO_AVAIL_LIST;
969 default:
970 return -EINVAL;
974 static const struct iio_info bmp280_info = {
975 .read_raw = &bmp280_read_raw,
976 .read_avail = &bmp280_read_avail,
977 .write_raw = &bmp280_write_raw,
980 static const unsigned long bmp280_avail_scan_masks[] = {
981 BIT(BMP280_TEMP) | BIT(BMP280_PRESS),
985 static const unsigned long bme280_avail_scan_masks[] = {
986 BIT(BME280_HUMID) | BIT(BMP280_TEMP) | BIT(BMP280_PRESS),
990 static int bmp280_preinit(struct bmp280_data *data)
992 struct device *dev = data->dev;
993 unsigned int reg;
994 int ret;
996 ret = regmap_write(data->regmap, BMP280_REG_RESET, BMP280_RST_SOFT_CMD);
997 if (ret)
998 return dev_err_probe(dev, ret, "Failed to reset device.\n");
1001 * According to the datasheet in Chapter 1: Specification, Table 2,
1002 * after resetting, the device uses the complete power-on sequence so
1003 * it needs to wait for the defined start-up time.
1005 fsleep(data->start_up_time);
1007 ret = regmap_read(data->regmap, BMP280_REG_STATUS, &reg);
1008 if (ret)
1009 return dev_err_probe(dev, ret, "Failed to read status register.\n");
1011 if (reg & BMP280_REG_STATUS_IM_UPDATE)
1012 return dev_err_probe(dev, -EIO, "Failed to copy NVM contents.\n");
1014 return 0;
1017 static const u8 bmp280_operation_mode[] = {
1018 [BMP280_SLEEP] = BMP280_MODE_SLEEP,
1019 [BMP280_FORCED] = BMP280_MODE_FORCED,
1020 [BMP280_NORMAL] = BMP280_MODE_NORMAL,
1023 static int bmp280_set_mode(struct bmp280_data *data, enum bmp280_op_mode mode)
1025 int ret;
1027 ret = regmap_write_bits(data->regmap, BMP280_REG_CTRL_MEAS,
1028 BMP280_MODE_MASK, bmp280_operation_mode[mode]);
1029 if (ret) {
1030 dev_err(data->dev, "failed to write ctrl_meas register.\n");
1031 return ret;
1034 data->op_mode = mode;
1036 return 0;
1039 static int bmp280_wait_conv(struct bmp280_data *data)
1041 unsigned int reg, meas_time_us;
1042 int ret;
1044 /* Check if we are using a BME280 device */
1045 if (data->oversampling_humid)
1046 meas_time_us = BMP280_PRESS_HUMID_MEAS_OFFSET +
1047 BIT(data->oversampling_humid) * BMP280_MEAS_DUR;
1049 else
1050 meas_time_us = 0;
1052 /* Pressure measurement time */
1053 meas_time_us += BMP280_PRESS_HUMID_MEAS_OFFSET +
1054 BIT(data->oversampling_press) * BMP280_MEAS_DUR;
1056 /* Temperature measurement time */
1057 meas_time_us += BIT(data->oversampling_temp) * BMP280_MEAS_DUR;
1059 /* Waiting time according to the BM(P/E)2 Sensor API */
1060 fsleep(meas_time_us);
1062 ret = regmap_read(data->regmap, BMP280_REG_STATUS, &reg);
1063 if (ret) {
1064 dev_err(data->dev, "failed to read status register.\n");
1065 return ret;
1068 if (reg & BMP280_REG_STATUS_MEAS_BIT) {
1069 dev_err(data->dev, "Measurement cycle didn't complete.\n");
1070 return -EBUSY;
1073 return 0;
1076 static int bmp280_chip_config(struct bmp280_data *data)
1078 u8 osrs = FIELD_PREP(BMP280_OSRS_TEMP_MASK, data->oversampling_temp + 1) |
1079 FIELD_PREP(BMP280_OSRS_PRESS_MASK, data->oversampling_press + 1);
1080 int ret;
1082 ret = regmap_write_bits(data->regmap, BMP280_REG_CTRL_MEAS,
1083 BMP280_OSRS_TEMP_MASK |
1084 BMP280_OSRS_PRESS_MASK |
1085 BMP280_MODE_MASK,
1086 osrs | BMP280_MODE_SLEEP);
1087 if (ret) {
1088 dev_err(data->dev, "failed to write ctrl_meas register\n");
1089 return ret;
1092 ret = regmap_update_bits(data->regmap, BMP280_REG_CONFIG,
1093 BMP280_FILTER_MASK,
1094 BMP280_FILTER_4X);
1095 if (ret) {
1096 dev_err(data->dev, "failed to write config register\n");
1097 return ret;
1100 return ret;
1103 static irqreturn_t bmp280_trigger_handler(int irq, void *p)
1105 struct iio_poll_func *pf = p;
1106 struct iio_dev *indio_dev = pf->indio_dev;
1107 struct bmp280_data *data = iio_priv(indio_dev);
1108 u32 adc_temp, adc_press, comp_press;
1109 s32 t_fine, comp_temp;
1110 s32 *chans = (s32 *)data->sensor_data;
1111 int ret;
1113 guard(mutex)(&data->lock);
1115 /* Burst read data registers */
1116 ret = regmap_bulk_read(data->regmap, BMP280_REG_PRESS_MSB,
1117 data->buf, BMP280_BURST_READ_BYTES);
1118 if (ret) {
1119 dev_err(data->dev, "failed to burst read sensor data\n");
1120 goto out;
1123 /* Temperature calculations */
1124 adc_temp = FIELD_GET(BMP280_MEAS_TRIM_MASK, get_unaligned_be24(&data->buf[3]));
1125 if (adc_temp == BMP280_TEMP_SKIPPED) {
1126 dev_err(data->dev, "reading temperature skipped\n");
1127 goto out;
1130 comp_temp = bmp280_compensate_temp(data, adc_temp);
1132 /* Pressure calculations */
1133 adc_press = FIELD_GET(BMP280_MEAS_TRIM_MASK, get_unaligned_be24(&data->buf[0]));
1134 if (adc_press == BMP280_PRESS_SKIPPED) {
1135 dev_err(data->dev, "reading pressure skipped\n");
1136 goto out;
1139 t_fine = bmp280_calc_t_fine(data, adc_temp);
1140 comp_press = bmp280_compensate_press(data, adc_press, t_fine);
1142 chans[0] = comp_press;
1143 chans[1] = comp_temp;
1145 iio_push_to_buffers_with_timestamp(indio_dev, data->sensor_data,
1146 iio_get_time_ns(indio_dev));
1148 out:
1149 iio_trigger_notify_done(indio_dev->trig);
1151 return IRQ_HANDLED;
1154 static const int bmp280_oversampling_avail[] = { 1, 2, 4, 8, 16 };
1155 static const u8 bmp280_chip_ids[] = { BMP280_CHIP_ID };
1156 static const int bmp280_temp_coeffs[] = { 10, 1 };
1157 static const int bmp280_press_coeffs[] = { 1, 256000 };
1159 const struct bmp280_chip_info bmp280_chip_info = {
1160 .id_reg = BMP280_REG_ID,
1161 .chip_id = bmp280_chip_ids,
1162 .num_chip_id = ARRAY_SIZE(bmp280_chip_ids),
1163 .regmap_config = &bmp280_regmap_config,
1164 .start_up_time = 2000,
1165 .channels = bmp280_channels,
1166 .num_channels = ARRAY_SIZE(bmp280_channels),
1167 .avail_scan_masks = bmp280_avail_scan_masks,
1169 .oversampling_temp_avail = bmp280_oversampling_avail,
1170 .num_oversampling_temp_avail = ARRAY_SIZE(bmp280_oversampling_avail),
1172 * Oversampling config values on BMx280 have one additional setting
1173 * that other generations of the family don't:
1174 * The value 0 means the measurement is bypassed instead of
1175 * oversampling set to x1.
1177 * To account for this difference, and preserve the same common
1178 * config logic, this is handled later on chip_config callback
1179 * incrementing one unit the oversampling setting.
1181 .oversampling_temp_default = BMP280_OSRS_TEMP_2X - 1,
1183 .oversampling_press_avail = bmp280_oversampling_avail,
1184 .num_oversampling_press_avail = ARRAY_SIZE(bmp280_oversampling_avail),
1185 .oversampling_press_default = BMP280_OSRS_PRESS_16X - 1,
1187 .temp_coeffs = bmp280_temp_coeffs,
1188 .temp_coeffs_type = IIO_VAL_FRACTIONAL,
1189 .press_coeffs = bmp280_press_coeffs,
1190 .press_coeffs_type = IIO_VAL_FRACTIONAL,
1192 .chip_config = bmp280_chip_config,
1193 .read_temp = bmp280_read_temp,
1194 .read_press = bmp280_read_press,
1195 .read_calib = bmp280_read_calib,
1196 .set_mode = bmp280_set_mode,
1197 .wait_conv = bmp280_wait_conv,
1198 .preinit = bmp280_preinit,
1200 .trigger_handler = bmp280_trigger_handler,
1202 EXPORT_SYMBOL_NS(bmp280_chip_info, IIO_BMP280);
1204 static int bme280_chip_config(struct bmp280_data *data)
1206 u8 osrs = FIELD_PREP(BME280_OSRS_HUMIDITY_MASK, data->oversampling_humid + 1);
1207 int ret;
1210 * Oversampling of humidity must be set before oversampling of
1211 * temperature/pressure is set to become effective.
1213 ret = regmap_update_bits(data->regmap, BME280_REG_CTRL_HUMIDITY,
1214 BME280_OSRS_HUMIDITY_MASK, osrs);
1215 if (ret) {
1216 dev_err(data->dev, "failed to set humidity oversampling");
1217 return ret;
1220 return bmp280_chip_config(data);
1223 static irqreturn_t bme280_trigger_handler(int irq, void *p)
1225 struct iio_poll_func *pf = p;
1226 struct iio_dev *indio_dev = pf->indio_dev;
1227 struct bmp280_data *data = iio_priv(indio_dev);
1228 u32 adc_temp, adc_press, adc_humidity, comp_press, comp_humidity;
1229 s32 t_fine, comp_temp;
1230 s32 *chans = (s32 *)data->sensor_data;
1231 int ret;
1233 guard(mutex)(&data->lock);
1235 /* Burst read data registers */
1236 ret = regmap_bulk_read(data->regmap, BMP280_REG_PRESS_MSB,
1237 data->buf, BME280_BURST_READ_BYTES);
1238 if (ret) {
1239 dev_err(data->dev, "failed to burst read sensor data\n");
1240 goto out;
1243 /* Temperature calculations */
1244 adc_temp = FIELD_GET(BMP280_MEAS_TRIM_MASK, get_unaligned_be24(&data->buf[3]));
1245 if (adc_temp == BMP280_TEMP_SKIPPED) {
1246 dev_err(data->dev, "reading temperature skipped\n");
1247 goto out;
1250 comp_temp = bmp280_compensate_temp(data, adc_temp);
1252 /* Pressure calculations */
1253 adc_press = FIELD_GET(BMP280_MEAS_TRIM_MASK, get_unaligned_be24(&data->buf[0]));
1254 if (adc_press == BMP280_PRESS_SKIPPED) {
1255 dev_err(data->dev, "reading pressure skipped\n");
1256 goto out;
1259 t_fine = bmp280_calc_t_fine(data, adc_temp);
1260 comp_press = bmp280_compensate_press(data, adc_press, t_fine);
1262 /* Humidity calculations */
1263 adc_humidity = get_unaligned_be16(&data->buf[6]);
1265 if (adc_humidity == BMP280_HUMIDITY_SKIPPED) {
1266 dev_err(data->dev, "reading humidity skipped\n");
1267 goto out;
1270 comp_humidity = bme280_compensate_humidity(data, adc_humidity, t_fine);
1272 chans[0] = comp_press;
1273 chans[1] = comp_temp;
1274 chans[2] = comp_humidity;
1276 iio_push_to_buffers_with_timestamp(indio_dev, data->sensor_data,
1277 iio_get_time_ns(indio_dev));
1279 out:
1280 iio_trigger_notify_done(indio_dev->trig);
1282 return IRQ_HANDLED;
1285 static int __bmp280_trigger_probe(struct iio_dev *indio_dev,
1286 const struct iio_trigger_ops *trigger_ops,
1287 int (*int_pin_config)(struct bmp280_data *data),
1288 irq_handler_t irq_thread_handler)
1290 struct bmp280_data *data = iio_priv(indio_dev);
1291 struct device *dev = data->dev;
1292 u32 irq_type;
1293 int ret, irq;
1295 irq = fwnode_irq_get(dev_fwnode(dev), 0);
1296 if (irq < 0)
1297 return dev_err_probe(dev, irq, "No interrupt found.\n");
1299 irq_type = irq_get_trigger_type(irq);
1300 switch (irq_type) {
1301 case IRQF_TRIGGER_RISING:
1302 data->trig_active_high = true;
1303 break;
1304 case IRQF_TRIGGER_FALLING:
1305 data->trig_active_high = false;
1306 break;
1307 default:
1308 return dev_err_probe(dev, -EINVAL, "Invalid interrupt type specified.\n");
1311 data->trig_open_drain =
1312 fwnode_property_read_bool(dev_fwnode(dev), "int-open-drain");
1314 ret = int_pin_config(data);
1315 if (ret)
1316 return ret;
1318 data->trig = devm_iio_trigger_alloc(data->dev, "%s-dev%d",
1319 indio_dev->name,
1320 iio_device_id(indio_dev));
1321 if (!data->trig)
1322 return -ENOMEM;
1324 data->trig->ops = trigger_ops;
1325 iio_trigger_set_drvdata(data->trig, data);
1327 ret = devm_request_threaded_irq(data->dev, irq, NULL,
1328 irq_thread_handler, IRQF_ONESHOT,
1329 indio_dev->name, indio_dev);
1330 if (ret)
1331 return dev_err_probe(dev, ret, "request IRQ failed.\n");
1333 ret = devm_iio_trigger_register(data->dev, data->trig);
1334 if (ret)
1335 return dev_err_probe(dev, ret, "iio trigger register failed.\n");
1337 indio_dev->trig = iio_trigger_get(data->trig);
1339 return 0;
1342 static const u8 bme280_chip_ids[] = { BME280_CHIP_ID };
1343 static const int bme280_humid_coeffs[] = { 1000, 1024 };
1345 const struct bmp280_chip_info bme280_chip_info = {
1346 .id_reg = BMP280_REG_ID,
1347 .chip_id = bme280_chip_ids,
1348 .num_chip_id = ARRAY_SIZE(bme280_chip_ids),
1349 .regmap_config = &bme280_regmap_config,
1350 .start_up_time = 2000,
1351 .channels = bme280_channels,
1352 .num_channels = ARRAY_SIZE(bme280_channels),
1353 .avail_scan_masks = bme280_avail_scan_masks,
1355 .oversampling_temp_avail = bmp280_oversampling_avail,
1356 .num_oversampling_temp_avail = ARRAY_SIZE(bmp280_oversampling_avail),
1357 .oversampling_temp_default = BMP280_OSRS_TEMP_2X - 1,
1359 .oversampling_press_avail = bmp280_oversampling_avail,
1360 .num_oversampling_press_avail = ARRAY_SIZE(bmp280_oversampling_avail),
1361 .oversampling_press_default = BMP280_OSRS_PRESS_16X - 1,
1363 .oversampling_humid_avail = bmp280_oversampling_avail,
1364 .num_oversampling_humid_avail = ARRAY_SIZE(bmp280_oversampling_avail),
1365 .oversampling_humid_default = BME280_OSRS_HUMIDITY_16X - 1,
1367 .temp_coeffs = bmp280_temp_coeffs,
1368 .temp_coeffs_type = IIO_VAL_FRACTIONAL,
1369 .press_coeffs = bmp280_press_coeffs,
1370 .press_coeffs_type = IIO_VAL_FRACTIONAL,
1371 .humid_coeffs = bme280_humid_coeffs,
1372 .humid_coeffs_type = IIO_VAL_FRACTIONAL,
1374 .chip_config = bme280_chip_config,
1375 .read_temp = bmp280_read_temp,
1376 .read_press = bmp280_read_press,
1377 .read_humid = bme280_read_humid,
1378 .read_calib = bme280_read_calib,
1379 .set_mode = bmp280_set_mode,
1380 .wait_conv = bmp280_wait_conv,
1381 .preinit = bmp280_preinit,
1383 .trigger_handler = bme280_trigger_handler,
1385 EXPORT_SYMBOL_NS(bme280_chip_info, IIO_BMP280);
1388 * Helper function to send a command to BMP3XX sensors.
1390 * Sensor processes commands written to the CMD register and signals
1391 * execution result through "cmd_rdy" and "cmd_error" flags available on
1392 * STATUS and ERROR registers.
1394 static int bmp380_cmd(struct bmp280_data *data, u8 cmd)
1396 unsigned int reg;
1397 int ret;
1399 /* Check if device is ready to process a command */
1400 ret = regmap_read(data->regmap, BMP380_REG_STATUS, &reg);
1401 if (ret) {
1402 dev_err(data->dev, "failed to read error register\n");
1403 return ret;
1405 if (!(reg & BMP380_STATUS_CMD_RDY_MASK)) {
1406 dev_err(data->dev, "device is not ready to accept commands\n");
1407 return -EBUSY;
1410 /* Send command to process */
1411 ret = regmap_write(data->regmap, BMP380_REG_CMD, cmd);
1412 if (ret) {
1413 dev_err(data->dev, "failed to send command to device\n");
1414 return ret;
1416 /* Wait for 2ms for command to be processed */
1417 usleep_range(data->start_up_time, data->start_up_time + 100);
1418 /* Check for command processing error */
1419 ret = regmap_read(data->regmap, BMP380_REG_ERROR, &reg);
1420 if (ret) {
1421 dev_err(data->dev, "error reading ERROR reg\n");
1422 return ret;
1424 if (reg & BMP380_ERR_CMD_MASK) {
1425 dev_err(data->dev, "error processing command 0x%X\n", cmd);
1426 return -EINVAL;
1429 return 0;
1432 static int bmp380_read_temp_adc(struct bmp280_data *data, u32 *adc_temp)
1434 u32 value_temp;
1435 int ret;
1437 ret = regmap_bulk_read(data->regmap, BMP380_REG_TEMP_XLSB,
1438 data->buf, BMP280_NUM_TEMP_BYTES);
1439 if (ret) {
1440 dev_err(data->dev, "failed to read temperature\n");
1441 return ret;
1444 value_temp = get_unaligned_le24(data->buf);
1445 if (value_temp == BMP380_TEMP_SKIPPED) {
1446 dev_err(data->dev, "reading temperature skipped\n");
1447 return -EIO;
1449 *adc_temp = value_temp;
1451 return 0;
1455 * Returns temperature in Celsius degrees, resolution is 0.01º C. Output value
1456 * of "5123" equals 51.2º C. t_fine carries fine temperature as global value.
1458 * Taken from datasheet, Section Appendix 9, "Compensation formula" and repo
1459 * https://github.com/BoschSensortec/BMP3-Sensor-API.
1461 static s32 bmp380_calc_t_fine(struct bmp280_data *data, u32 adc_temp)
1463 s64 var1, var2, var3, var4, var5, var6;
1464 struct bmp380_calib *calib = &data->calib.bmp380;
1466 var1 = ((s64) adc_temp) - (((s64) calib->T1) << 8);
1467 var2 = var1 * ((s64) calib->T2);
1468 var3 = var1 * var1;
1469 var4 = var3 * ((s64) calib->T3);
1470 var5 = (var2 << 18) + var4;
1471 var6 = var5 >> 32;
1472 return (s32)var6; /* t_fine = var6 */
1475 static int bmp380_get_t_fine(struct bmp280_data *data, s32 *t_fine)
1477 s32 adc_temp;
1478 int ret;
1480 ret = bmp380_read_temp_adc(data, &adc_temp);
1481 if (ret)
1482 return ret;
1484 *t_fine = bmp380_calc_t_fine(data, adc_temp);
1486 return 0;
1489 static int bmp380_compensate_temp(struct bmp280_data *data, u32 adc_temp)
1491 s64 comp_temp;
1492 s32 var6;
1494 var6 = bmp380_calc_t_fine(data, adc_temp);
1495 comp_temp = (var6 * 25) >> 14;
1497 comp_temp = clamp_val(comp_temp, BMP380_MIN_TEMP, BMP380_MAX_TEMP);
1498 return (s32) comp_temp;
1501 static int bmp380_read_press_adc(struct bmp280_data *data, u32 *adc_press)
1503 u32 value_press;
1504 int ret;
1506 ret = regmap_bulk_read(data->regmap, BMP380_REG_PRESS_XLSB,
1507 data->buf, BMP280_NUM_PRESS_BYTES);
1508 if (ret) {
1509 dev_err(data->dev, "failed to read pressure\n");
1510 return ret;
1513 value_press = get_unaligned_le24(data->buf);
1514 if (value_press == BMP380_PRESS_SKIPPED) {
1515 dev_err(data->dev, "reading pressure skipped\n");
1516 return -EIO;
1518 *adc_press = value_press;
1520 return 0;
1524 * Returns pressure in Pa as an unsigned 32 bit integer in fractional Pascal.
1525 * Output value of "9528709" represents 9528709/100 = 95287.09 Pa = 952.8709 hPa.
1527 * Taken from datasheet, Section 9.3. "Pressure compensation" and repository
1528 * https://github.com/BoschSensortec/BMP3-Sensor-API.
1530 static u32 bmp380_compensate_press(struct bmp280_data *data,
1531 u32 adc_press, s32 t_fine)
1533 s64 var1, var2, var3, var4, var5, var6, offset, sensitivity;
1534 struct bmp380_calib *calib = &data->calib.bmp380;
1535 u32 comp_press;
1537 var1 = (s64)t_fine * (s64)t_fine;
1538 var2 = var1 >> 6;
1539 var3 = (var2 * ((s64)t_fine)) >> 8;
1540 var4 = ((s64)calib->P8 * var3) >> 5;
1541 var5 = ((s64)calib->P7 * var1) << 4;
1542 var6 = ((s64)calib->P6 * (s64)t_fine) << 22;
1543 offset = ((s64)calib->P5 << 47) + var4 + var5 + var6;
1544 var2 = ((s64)calib->P4 * var3) >> 5;
1545 var4 = ((s64)calib->P3 * var1) << 2;
1546 var5 = ((s64)calib->P2 - ((s64)1 << 14)) *
1547 ((s64)t_fine << 21);
1548 sensitivity = (((s64) calib->P1 - ((s64) 1 << 14)) << 46) +
1549 var2 + var4 + var5;
1550 var1 = (sensitivity >> 24) * (s64)adc_press;
1551 var2 = (s64)calib->P10 * (s64)t_fine;
1552 var3 = var2 + ((s64)calib->P9 << 16);
1553 var4 = (var3 * (s64)adc_press) >> 13;
1556 * Dividing by 10 followed by multiplying by 10 to avoid
1557 * possible overflow caused by (uncomp_data->pressure * partial_data4).
1559 var5 = ((s64)adc_press * div_s64(var4, 10)) >> 9;
1560 var5 *= 10;
1561 var6 = (s64)adc_press * (s64)adc_press;
1562 var2 = ((s64)calib->P11 * var6) >> 16;
1563 var3 = (var2 * (s64)adc_press) >> 7;
1564 var4 = (offset >> 2) + var1 + var5 + var3;
1565 comp_press = ((u64)var4 * 25) >> 40;
1567 comp_press = clamp_val(comp_press, BMP380_MIN_PRES, BMP380_MAX_PRES);
1568 return comp_press;
1571 static int bmp380_read_temp(struct bmp280_data *data, s32 *comp_temp)
1573 u32 adc_temp;
1574 int ret;
1576 ret = bmp380_read_temp_adc(data, &adc_temp);
1577 if (ret)
1578 return ret;
1580 *comp_temp = bmp380_compensate_temp(data, adc_temp);
1582 return 0;
1585 static int bmp380_read_press(struct bmp280_data *data, u32 *comp_press)
1587 u32 adc_press, t_fine;
1588 int ret;
1590 ret = bmp380_get_t_fine(data, &t_fine);
1591 if (ret)
1592 return ret;
1594 ret = bmp380_read_press_adc(data, &adc_press);
1595 if (ret)
1596 return ret;
1598 *comp_press = bmp380_compensate_press(data, adc_press, t_fine);
1600 return 0;
1603 static int bmp380_read_calib(struct bmp280_data *data)
1605 struct bmp380_calib *calib = &data->calib.bmp380;
1606 int ret;
1608 /* Read temperature and pressure calibration data */
1609 ret = regmap_bulk_read(data->regmap, BMP380_REG_CALIB_TEMP_START,
1610 data->bmp380_cal_buf,
1611 sizeof(data->bmp380_cal_buf));
1612 if (ret) {
1613 dev_err(data->dev,
1614 "failed to read calibration parameters\n");
1615 return ret;
1618 /* Toss the temperature calibration data into the entropy pool */
1619 add_device_randomness(data->bmp380_cal_buf,
1620 sizeof(data->bmp380_cal_buf));
1622 /* Parse calibration values */
1623 calib->T1 = get_unaligned_le16(&data->bmp380_cal_buf[BMP380_T1]);
1624 calib->T2 = get_unaligned_le16(&data->bmp380_cal_buf[BMP380_T2]);
1625 calib->T3 = data->bmp380_cal_buf[BMP380_T3];
1626 calib->P1 = get_unaligned_le16(&data->bmp380_cal_buf[BMP380_P1]);
1627 calib->P2 = get_unaligned_le16(&data->bmp380_cal_buf[BMP380_P2]);
1628 calib->P3 = data->bmp380_cal_buf[BMP380_P3];
1629 calib->P4 = data->bmp380_cal_buf[BMP380_P4];
1630 calib->P5 = get_unaligned_le16(&data->bmp380_cal_buf[BMP380_P5]);
1631 calib->P6 = get_unaligned_le16(&data->bmp380_cal_buf[BMP380_P6]);
1632 calib->P7 = data->bmp380_cal_buf[BMP380_P7];
1633 calib->P8 = data->bmp380_cal_buf[BMP380_P8];
1634 calib->P9 = get_unaligned_le16(&data->bmp380_cal_buf[BMP380_P9]);
1635 calib->P10 = data->bmp380_cal_buf[BMP380_P10];
1636 calib->P11 = data->bmp380_cal_buf[BMP380_P11];
1638 return 0;
1641 static const int bmp380_odr_table[][2] = {
1642 [BMP380_ODR_200HZ] = {200, 0},
1643 [BMP380_ODR_100HZ] = {100, 0},
1644 [BMP380_ODR_50HZ] = {50, 0},
1645 [BMP380_ODR_25HZ] = {25, 0},
1646 [BMP380_ODR_12_5HZ] = {12, 500000},
1647 [BMP380_ODR_6_25HZ] = {6, 250000},
1648 [BMP380_ODR_3_125HZ] = {3, 125000},
1649 [BMP380_ODR_1_5625HZ] = {1, 562500},
1650 [BMP380_ODR_0_78HZ] = {0, 781250},
1651 [BMP380_ODR_0_39HZ] = {0, 390625},
1652 [BMP380_ODR_0_2HZ] = {0, 195313},
1653 [BMP380_ODR_0_1HZ] = {0, 97656},
1654 [BMP380_ODR_0_05HZ] = {0, 48828},
1655 [BMP380_ODR_0_02HZ] = {0, 24414},
1656 [BMP380_ODR_0_01HZ] = {0, 12207},
1657 [BMP380_ODR_0_006HZ] = {0, 6104},
1658 [BMP380_ODR_0_003HZ] = {0, 3052},
1659 [BMP380_ODR_0_0015HZ] = {0, 1526},
1662 static int bmp380_preinit(struct bmp280_data *data)
1664 /* BMP3xx requires soft-reset as part of initialization */
1665 return bmp380_cmd(data, BMP380_CMD_SOFT_RESET);
1668 static const u8 bmp380_operation_mode[] = {
1669 [BMP280_SLEEP] = BMP380_MODE_SLEEP,
1670 [BMP280_FORCED] = BMP380_MODE_FORCED,
1671 [BMP280_NORMAL] = BMP380_MODE_NORMAL,
1674 static int bmp380_set_mode(struct bmp280_data *data, enum bmp280_op_mode mode)
1676 int ret;
1678 ret = regmap_write_bits(data->regmap, BMP380_REG_POWER_CONTROL,
1679 BMP380_MODE_MASK,
1680 FIELD_PREP(BMP380_MODE_MASK,
1681 bmp380_operation_mode[mode]));
1682 if (ret) {
1683 dev_err(data->dev, "failed to write power control register.\n");
1684 return ret;
1687 data->op_mode = mode;
1689 return 0;
1692 static int bmp380_wait_conv(struct bmp280_data *data)
1694 unsigned int reg;
1695 int ret, meas_time_us;
1697 /* Offset measurement time */
1698 meas_time_us = BMP380_MEAS_OFFSET;
1700 /* Pressure measurement time */
1701 meas_time_us += BMP380_PRESS_MEAS_OFFSET +
1702 BIT(data->oversampling_press) * BMP380_MEAS_DUR;
1704 /* Temperature measurement time */
1705 meas_time_us += BMP380_TEMP_MEAS_OFFSET +
1706 BIT(data->oversampling_temp) * BMP380_MEAS_DUR;
1708 /* Measurement time defined in Datasheet Section 3.9.2 */
1709 fsleep(meas_time_us);
1711 ret = regmap_read(data->regmap, BMP380_REG_STATUS, &reg);
1712 if (ret) {
1713 dev_err(data->dev, "failed to read status register.\n");
1714 return ret;
1717 if (!((reg & BMP380_STATUS_DRDY_PRESS_MASK) &&
1718 (reg & BMP380_STATUS_DRDY_TEMP_MASK))) {
1719 dev_err(data->dev, "Measurement cycle didn't complete.\n");
1720 return -EBUSY;
1723 return 0;
1726 static int bmp380_chip_config(struct bmp280_data *data)
1728 bool change = false, aux;
1729 unsigned int tmp;
1730 u8 osrs;
1731 int ret;
1733 /* Configure power control register */
1734 ret = regmap_update_bits(data->regmap, BMP380_REG_POWER_CONTROL,
1735 BMP380_CTRL_SENSORS_MASK,
1736 BMP380_CTRL_SENSORS_PRESS_EN |
1737 BMP380_CTRL_SENSORS_TEMP_EN);
1738 if (ret) {
1739 dev_err(data->dev,
1740 "failed to write operation control register\n");
1741 return ret;
1744 /* Configure oversampling */
1745 osrs = FIELD_PREP(BMP380_OSRS_TEMP_MASK, data->oversampling_temp) |
1746 FIELD_PREP(BMP380_OSRS_PRESS_MASK, data->oversampling_press);
1748 ret = regmap_update_bits_check(data->regmap, BMP380_REG_OSR,
1749 BMP380_OSRS_TEMP_MASK |
1750 BMP380_OSRS_PRESS_MASK,
1751 osrs, &aux);
1752 if (ret) {
1753 dev_err(data->dev, "failed to write oversampling register\n");
1754 return ret;
1756 change = change || aux;
1758 /* Configure output data rate */
1759 ret = regmap_update_bits_check(data->regmap, BMP380_REG_ODR,
1760 BMP380_ODRS_MASK, data->sampling_freq,
1761 &aux);
1762 if (ret) {
1763 dev_err(data->dev, "failed to write ODR selection register\n");
1764 return ret;
1766 change = change || aux;
1768 /* Set filter data */
1769 ret = regmap_update_bits(data->regmap, BMP380_REG_CONFIG, BMP380_FILTER_MASK,
1770 FIELD_PREP(BMP380_FILTER_MASK, data->iir_filter_coeff));
1771 if (ret) {
1772 dev_err(data->dev, "failed to write config register\n");
1773 return ret;
1776 if (change) {
1778 * The configurations errors are detected on the fly during a
1779 * measurement cycle. If the sampling frequency is too low, it's
1780 * faster to reset the measurement loop than wait until the next
1781 * measurement is due.
1783 * Resets sensor measurement loop toggling between sleep and
1784 * normal operating modes.
1786 ret = bmp380_set_mode(data, BMP280_SLEEP);
1787 if (ret) {
1788 dev_err(data->dev, "failed to set sleep mode\n");
1789 return ret;
1793 * According to the BMP3 Sensor API, the sensor needs 5ms
1794 * in order to go to the sleep mode.
1796 fsleep(5 * USEC_PER_MSEC);
1798 ret = bmp380_set_mode(data, BMP280_NORMAL);
1799 if (ret) {
1800 dev_err(data->dev, "failed to set normal mode\n");
1801 return ret;
1804 * Waits for measurement before checking configuration error
1805 * flag. Selected longest measurement time, calculated from
1806 * formula in datasheet section 3.9.2 with an offset of ~+15%
1807 * as it seen as well in table 3.9.1.
1809 msleep(150);
1811 /* Check config error flag */
1812 ret = regmap_read(data->regmap, BMP380_REG_ERROR, &tmp);
1813 if (ret) {
1814 dev_err(data->dev, "failed to read error register\n");
1815 return ret;
1817 if (tmp & BMP380_ERR_CONF_MASK) {
1818 dev_warn(data->dev,
1819 "sensor flagged configuration as incompatible\n");
1820 return -EINVAL;
1824 /* Dummy read to empty data registers. */
1825 ret = bmp380_read_press(data, &tmp);
1826 if (ret)
1827 return ret;
1829 ret = bmp380_set_mode(data, BMP280_SLEEP);
1830 if (ret)
1831 dev_err(data->dev, "failed to set sleep mode.\n");
1833 return ret;
1836 static int bmp380_data_rdy_trigger_set_state(struct iio_trigger *trig,
1837 bool state)
1839 struct bmp280_data *data = iio_trigger_get_drvdata(trig);
1840 int ret;
1842 guard(mutex)(&data->lock);
1844 ret = regmap_update_bits(data->regmap, BMP380_REG_INT_CONTROL,
1845 BMP380_INT_CTRL_DRDY_EN,
1846 FIELD_PREP(BMP380_INT_CTRL_DRDY_EN, !!state));
1847 if (ret)
1848 dev_err(data->dev,
1849 "Could not %s interrupt.\n", str_enable_disable(state));
1850 return ret;
1853 static const struct iio_trigger_ops bmp380_trigger_ops = {
1854 .set_trigger_state = &bmp380_data_rdy_trigger_set_state,
1857 static int bmp380_int_pin_config(struct bmp280_data *data)
1859 int pin_drive_cfg = FIELD_PREP(BMP380_INT_CTRL_OPEN_DRAIN,
1860 data->trig_open_drain);
1861 int pin_level_cfg = FIELD_PREP(BMP380_INT_CTRL_LEVEL,
1862 data->trig_active_high);
1863 int ret, int_pin_cfg = pin_drive_cfg | pin_level_cfg;
1865 ret = regmap_update_bits(data->regmap, BMP380_REG_INT_CONTROL,
1866 BMP380_INT_CTRL_SETTINGS_MASK, int_pin_cfg);
1867 if (ret)
1868 dev_err(data->dev, "Could not set interrupt settings.\n");
1870 return ret;
1873 static irqreturn_t bmp380_irq_thread_handler(int irq, void *p)
1875 struct iio_dev *indio_dev = p;
1876 struct bmp280_data *data = iio_priv(indio_dev);
1877 unsigned int int_ctrl;
1878 int ret;
1880 ret = regmap_read(data->regmap, BMP380_REG_INT_STATUS, &int_ctrl);
1881 if (ret)
1882 return IRQ_NONE;
1884 if (FIELD_GET(BMP380_INT_STATUS_DRDY, int_ctrl))
1885 iio_trigger_poll_nested(data->trig);
1887 return IRQ_HANDLED;
1890 static int bmp380_trigger_probe(struct iio_dev *indio_dev)
1892 return __bmp280_trigger_probe(indio_dev, &bmp380_trigger_ops,
1893 bmp380_int_pin_config,
1894 bmp380_irq_thread_handler);
1897 static irqreturn_t bmp380_trigger_handler(int irq, void *p)
1899 struct iio_poll_func *pf = p;
1900 struct iio_dev *indio_dev = pf->indio_dev;
1901 struct bmp280_data *data = iio_priv(indio_dev);
1902 u32 adc_temp, adc_press, comp_press;
1903 s32 t_fine, comp_temp;
1904 s32 *chans = (s32 *)data->sensor_data;
1905 int ret;
1907 guard(mutex)(&data->lock);
1909 /* Burst read data registers */
1910 ret = regmap_bulk_read(data->regmap, BMP380_REG_PRESS_XLSB,
1911 data->buf, BMP280_BURST_READ_BYTES);
1912 if (ret) {
1913 dev_err(data->dev, "failed to burst read sensor data\n");
1914 goto out;
1917 /* Temperature calculations */
1918 adc_temp = get_unaligned_le24(&data->buf[3]);
1919 if (adc_temp == BMP380_TEMP_SKIPPED) {
1920 dev_err(data->dev, "reading temperature skipped\n");
1921 goto out;
1924 comp_temp = bmp380_compensate_temp(data, adc_temp);
1926 /* Pressure calculations */
1927 adc_press = get_unaligned_le24(&data->buf[0]);
1928 if (adc_press == BMP380_PRESS_SKIPPED) {
1929 dev_err(data->dev, "reading pressure skipped\n");
1930 goto out;
1933 t_fine = bmp380_calc_t_fine(data, adc_temp);
1934 comp_press = bmp380_compensate_press(data, adc_press, t_fine);
1936 chans[0] = comp_press;
1937 chans[1] = comp_temp;
1939 iio_push_to_buffers_with_timestamp(indio_dev, data->sensor_data,
1940 iio_get_time_ns(indio_dev));
1942 out:
1943 iio_trigger_notify_done(indio_dev->trig);
1945 return IRQ_HANDLED;
1948 static const int bmp380_oversampling_avail[] = { 1, 2, 4, 8, 16, 32 };
1949 static const int bmp380_iir_filter_coeffs_avail[] = { 1, 2, 4, 8, 16, 32, 64, 128};
1950 static const u8 bmp380_chip_ids[] = { BMP380_CHIP_ID, BMP390_CHIP_ID };
1951 static const int bmp380_temp_coeffs[] = { 10, 1 };
1952 static const int bmp380_press_coeffs[] = { 1, 100000 };
1954 const struct bmp280_chip_info bmp380_chip_info = {
1955 .id_reg = BMP380_REG_ID,
1956 .chip_id = bmp380_chip_ids,
1957 .num_chip_id = ARRAY_SIZE(bmp380_chip_ids),
1958 .regmap_config = &bmp380_regmap_config,
1959 .spi_read_extra_byte = true,
1960 .start_up_time = 2000,
1961 .channels = bmp380_channels,
1962 .num_channels = ARRAY_SIZE(bmp380_channels),
1963 .avail_scan_masks = bmp280_avail_scan_masks,
1965 .oversampling_temp_avail = bmp380_oversampling_avail,
1966 .num_oversampling_temp_avail = ARRAY_SIZE(bmp380_oversampling_avail),
1967 .oversampling_temp_default = ilog2(1),
1969 .oversampling_press_avail = bmp380_oversampling_avail,
1970 .num_oversampling_press_avail = ARRAY_SIZE(bmp380_oversampling_avail),
1971 .oversampling_press_default = ilog2(4),
1973 .sampling_freq_avail = bmp380_odr_table,
1974 .num_sampling_freq_avail = ARRAY_SIZE(bmp380_odr_table) * 2,
1975 .sampling_freq_default = BMP380_ODR_50HZ,
1977 .iir_filter_coeffs_avail = bmp380_iir_filter_coeffs_avail,
1978 .num_iir_filter_coeffs_avail = ARRAY_SIZE(bmp380_iir_filter_coeffs_avail),
1979 .iir_filter_coeff_default = 2,
1981 .temp_coeffs = bmp380_temp_coeffs,
1982 .temp_coeffs_type = IIO_VAL_FRACTIONAL,
1983 .press_coeffs = bmp380_press_coeffs,
1984 .press_coeffs_type = IIO_VAL_FRACTIONAL,
1986 .chip_config = bmp380_chip_config,
1987 .read_temp = bmp380_read_temp,
1988 .read_press = bmp380_read_press,
1989 .read_calib = bmp380_read_calib,
1990 .set_mode = bmp380_set_mode,
1991 .wait_conv = bmp380_wait_conv,
1992 .preinit = bmp380_preinit,
1994 .trigger_probe = bmp380_trigger_probe,
1995 .trigger_handler = bmp380_trigger_handler,
1997 EXPORT_SYMBOL_NS(bmp380_chip_info, IIO_BMP280);
1999 static int bmp580_soft_reset(struct bmp280_data *data)
2001 unsigned int reg;
2002 int ret;
2004 ret = regmap_write(data->regmap, BMP580_REG_CMD, BMP580_CMD_SOFT_RESET);
2005 if (ret) {
2006 dev_err(data->dev, "failed to send reset command to device\n");
2007 return ret;
2009 usleep_range(2000, 2500);
2011 /* Dummy read of chip_id */
2012 ret = regmap_read(data->regmap, BMP580_REG_CHIP_ID, &reg);
2013 if (ret) {
2014 dev_err(data->dev, "failed to reestablish comms after reset\n");
2015 return ret;
2018 ret = regmap_read(data->regmap, BMP580_REG_INT_STATUS, &reg);
2019 if (ret) {
2020 dev_err(data->dev, "error reading interrupt status register\n");
2021 return ret;
2023 if (!(reg & BMP580_INT_STATUS_POR_MASK)) {
2024 dev_err(data->dev, "error resetting sensor\n");
2025 return -EINVAL;
2028 return 0;
2032 * bmp580_nvm_operation() - Helper function to commit NVM memory operations
2033 * @data: sensor data struct
2034 * @is_write: flag to signal write operation
2036 static int bmp580_nvm_operation(struct bmp280_data *data, bool is_write)
2038 unsigned long timeout, poll;
2039 unsigned int reg;
2040 int ret;
2042 /* Check NVM ready flag */
2043 ret = regmap_read(data->regmap, BMP580_REG_STATUS, &reg);
2044 if (ret) {
2045 dev_err(data->dev, "failed to check nvm status\n");
2046 return ret;
2048 if (!(reg & BMP580_STATUS_NVM_RDY_MASK)) {
2049 dev_err(data->dev, "sensor's nvm is not ready\n");
2050 return -EIO;
2053 /* Start NVM operation sequence */
2054 ret = regmap_write(data->regmap, BMP580_REG_CMD,
2055 BMP580_CMD_NVM_OP_SEQ_0);
2056 if (ret) {
2057 dev_err(data->dev,
2058 "failed to send nvm operation's first sequence\n");
2059 return ret;
2061 if (is_write) {
2062 /* Send NVM write sequence */
2063 ret = regmap_write(data->regmap, BMP580_REG_CMD,
2064 BMP580_CMD_NVM_WRITE_SEQ_1);
2065 if (ret) {
2066 dev_err(data->dev,
2067 "failed to send nvm write sequence\n");
2068 return ret;
2070 /* Datasheet says on 4.8.1.2 it takes approximately 10ms */
2071 poll = 2000;
2072 timeout = 12000;
2073 } else {
2074 /* Send NVM read sequence */
2075 ret = regmap_write(data->regmap, BMP580_REG_CMD,
2076 BMP580_CMD_NVM_READ_SEQ_1);
2077 if (ret) {
2078 dev_err(data->dev,
2079 "failed to send nvm read sequence\n");
2080 return ret;
2082 /* Datasheet says on 4.8.1.1 it takes approximately 200us */
2083 poll = 50;
2084 timeout = 400;
2087 /* Wait until NVM is ready again */
2088 ret = regmap_read_poll_timeout(data->regmap, BMP580_REG_STATUS, reg,
2089 (reg & BMP580_STATUS_NVM_RDY_MASK),
2090 poll, timeout);
2091 if (ret) {
2092 dev_err(data->dev, "error checking nvm operation status\n");
2093 return ret;
2096 /* Check NVM error flags */
2097 if ((reg & BMP580_STATUS_NVM_ERR_MASK) || (reg & BMP580_STATUS_NVM_CMD_ERR_MASK)) {
2098 dev_err(data->dev, "error processing nvm operation\n");
2099 return -EIO;
2102 return 0;
2106 * Contrary to previous sensors families, compensation algorithm is builtin.
2107 * We are only required to read the register raw data and adapt the ranges
2108 * for what is expected on IIO ABI.
2111 static int bmp580_read_temp(struct bmp280_data *data, s32 *raw_temp)
2113 s32 value_temp;
2114 int ret;
2116 ret = regmap_bulk_read(data->regmap, BMP580_REG_TEMP_XLSB,
2117 data->buf, BMP280_NUM_TEMP_BYTES);
2118 if (ret) {
2119 dev_err(data->dev, "failed to read temperature\n");
2120 return ret;
2123 value_temp = get_unaligned_le24(data->buf);
2124 if (value_temp == BMP580_TEMP_SKIPPED) {
2125 dev_err(data->dev, "reading temperature skipped\n");
2126 return -EIO;
2128 *raw_temp = sign_extend32(value_temp, 23);
2130 return 0;
2133 static int bmp580_read_press(struct bmp280_data *data, u32 *raw_press)
2135 u32 value_press;
2136 int ret;
2138 ret = regmap_bulk_read(data->regmap, BMP580_REG_PRESS_XLSB,
2139 data->buf, BMP280_NUM_PRESS_BYTES);
2140 if (ret) {
2141 dev_err(data->dev, "failed to read pressure\n");
2142 return ret;
2145 value_press = get_unaligned_le24(data->buf);
2146 if (value_press == BMP580_PRESS_SKIPPED) {
2147 dev_err(data->dev, "reading pressure skipped\n");
2148 return -EIO;
2150 *raw_press = value_press;
2152 return 0;
2155 static const int bmp580_odr_table[][2] = {
2156 [BMP580_ODR_240HZ] = {240, 0},
2157 [BMP580_ODR_218HZ] = {218, 0},
2158 [BMP580_ODR_199HZ] = {199, 0},
2159 [BMP580_ODR_179HZ] = {179, 0},
2160 [BMP580_ODR_160HZ] = {160, 0},
2161 [BMP580_ODR_149HZ] = {149, 0},
2162 [BMP580_ODR_140HZ] = {140, 0},
2163 [BMP580_ODR_129HZ] = {129, 0},
2164 [BMP580_ODR_120HZ] = {120, 0},
2165 [BMP580_ODR_110HZ] = {110, 0},
2166 [BMP580_ODR_100HZ] = {100, 0},
2167 [BMP580_ODR_89HZ] = {89, 0},
2168 [BMP580_ODR_80HZ] = {80, 0},
2169 [BMP580_ODR_70HZ] = {70, 0},
2170 [BMP580_ODR_60HZ] = {60, 0},
2171 [BMP580_ODR_50HZ] = {50, 0},
2172 [BMP580_ODR_45HZ] = {45, 0},
2173 [BMP580_ODR_40HZ] = {40, 0},
2174 [BMP580_ODR_35HZ] = {35, 0},
2175 [BMP580_ODR_30HZ] = {30, 0},
2176 [BMP580_ODR_25HZ] = {25, 0},
2177 [BMP580_ODR_20HZ] = {20, 0},
2178 [BMP580_ODR_15HZ] = {15, 0},
2179 [BMP580_ODR_10HZ] = {10, 0},
2180 [BMP580_ODR_5HZ] = {5, 0},
2181 [BMP580_ODR_4HZ] = {4, 0},
2182 [BMP580_ODR_3HZ] = {3, 0},
2183 [BMP580_ODR_2HZ] = {2, 0},
2184 [BMP580_ODR_1HZ] = {1, 0},
2185 [BMP580_ODR_0_5HZ] = {0, 500000},
2186 [BMP580_ODR_0_25HZ] = {0, 250000},
2187 [BMP580_ODR_0_125HZ] = {0, 125000},
2190 static const int bmp580_nvmem_addrs[] = { 0x20, 0x21, 0x22 };
2192 static int bmp580_nvmem_read_impl(void *priv, unsigned int offset, void *val,
2193 size_t bytes)
2195 struct bmp280_data *data = priv;
2196 u16 *dst = val;
2197 int ret, addr;
2199 guard(mutex)(&data->lock);
2201 /* Set sensor in standby mode */
2202 ret = regmap_update_bits(data->regmap, BMP580_REG_ODR_CONFIG,
2203 BMP580_MODE_MASK | BMP580_ODR_DEEPSLEEP_DIS,
2204 BMP580_ODR_DEEPSLEEP_DIS |
2205 FIELD_PREP(BMP580_MODE_MASK, BMP580_MODE_SLEEP));
2206 if (ret) {
2207 dev_err(data->dev, "failed to change sensor to standby mode\n");
2208 goto exit;
2210 /* Wait standby transition time */
2211 usleep_range(2500, 3000);
2213 while (bytes >= sizeof(*dst)) {
2214 addr = bmp580_nvmem_addrs[offset / sizeof(*dst)];
2216 ret = regmap_write(data->regmap, BMP580_REG_NVM_ADDR,
2217 FIELD_PREP(BMP580_NVM_ROW_ADDR_MASK, addr));
2218 if (ret) {
2219 dev_err(data->dev, "error writing nvm address\n");
2220 goto exit;
2223 ret = bmp580_nvm_operation(data, false);
2224 if (ret)
2225 goto exit;
2227 ret = regmap_bulk_read(data->regmap, BMP580_REG_NVM_DATA_LSB,
2228 &data->le16, sizeof(data->le16));
2229 if (ret) {
2230 dev_err(data->dev, "error reading nvm data regs\n");
2231 goto exit;
2234 *dst++ = le16_to_cpu(data->le16);
2235 bytes -= sizeof(*dst);
2236 offset += sizeof(*dst);
2238 exit:
2239 /* Restore chip config */
2240 data->chip_info->chip_config(data);
2241 return ret;
2244 static int bmp580_nvmem_read(void *priv, unsigned int offset, void *val,
2245 size_t bytes)
2247 struct bmp280_data *data = priv;
2248 int ret;
2250 pm_runtime_get_sync(data->dev);
2251 ret = bmp580_nvmem_read_impl(priv, offset, val, bytes);
2252 pm_runtime_mark_last_busy(data->dev);
2253 pm_runtime_put_autosuspend(data->dev);
2255 return ret;
2258 static int bmp580_nvmem_write_impl(void *priv, unsigned int offset, void *val,
2259 size_t bytes)
2261 struct bmp280_data *data = priv;
2262 u16 *buf = val;
2263 int ret, addr;
2265 guard(mutex)(&data->lock);
2267 /* Set sensor in standby mode */
2268 ret = regmap_update_bits(data->regmap, BMP580_REG_ODR_CONFIG,
2269 BMP580_MODE_MASK | BMP580_ODR_DEEPSLEEP_DIS,
2270 BMP580_ODR_DEEPSLEEP_DIS |
2271 FIELD_PREP(BMP580_MODE_MASK, BMP580_MODE_SLEEP));
2272 if (ret) {
2273 dev_err(data->dev, "failed to change sensor to standby mode\n");
2274 goto exit;
2276 /* Wait standby transition time */
2277 usleep_range(2500, 3000);
2279 while (bytes >= sizeof(*buf)) {
2280 addr = bmp580_nvmem_addrs[offset / sizeof(*buf)];
2282 ret = regmap_write(data->regmap, BMP580_REG_NVM_ADDR,
2283 BMP580_NVM_PROG_EN |
2284 FIELD_PREP(BMP580_NVM_ROW_ADDR_MASK, addr));
2285 if (ret) {
2286 dev_err(data->dev, "error writing nvm address\n");
2287 goto exit;
2289 data->le16 = cpu_to_le16(*buf++);
2291 ret = regmap_bulk_write(data->regmap, BMP580_REG_NVM_DATA_LSB,
2292 &data->le16, sizeof(data->le16));
2293 if (ret) {
2294 dev_err(data->dev, "error writing LSB NVM data regs\n");
2295 goto exit;
2298 ret = bmp580_nvm_operation(data, true);
2299 if (ret)
2300 goto exit;
2302 /* Disable programming mode bit */
2303 ret = regmap_clear_bits(data->regmap, BMP580_REG_NVM_ADDR,
2304 BMP580_NVM_PROG_EN);
2305 if (ret) {
2306 dev_err(data->dev, "error resetting nvm write\n");
2307 goto exit;
2310 bytes -= sizeof(*buf);
2311 offset += sizeof(*buf);
2313 exit:
2314 /* Restore chip config */
2315 data->chip_info->chip_config(data);
2316 return ret;
2319 static int bmp580_nvmem_write(void *priv, unsigned int offset, void *val,
2320 size_t bytes)
2322 struct bmp280_data *data = priv;
2323 int ret;
2325 pm_runtime_get_sync(data->dev);
2326 ret = bmp580_nvmem_write_impl(priv, offset, val, bytes);
2327 pm_runtime_mark_last_busy(data->dev);
2328 pm_runtime_put_autosuspend(data->dev);
2330 return ret;
2333 static int bmp580_preinit(struct bmp280_data *data)
2335 struct nvmem_config config = {
2336 .dev = data->dev,
2337 .priv = data,
2338 .name = "bmp580_nvmem",
2339 .word_size = sizeof(u16),
2340 .stride = sizeof(u16),
2341 .size = 3 * sizeof(u16),
2342 .reg_read = bmp580_nvmem_read,
2343 .reg_write = bmp580_nvmem_write,
2345 unsigned int reg;
2346 int ret;
2348 /* Issue soft-reset command */
2349 ret = bmp580_soft_reset(data);
2350 if (ret)
2351 return ret;
2353 /* Post powerup sequence */
2354 ret = regmap_read(data->regmap, BMP580_REG_CHIP_ID, &reg);
2355 if (ret) {
2356 dev_err(data->dev, "failed to establish comms with the chip\n");
2357 return ret;
2360 /* Print warn message if we don't know the chip id */
2361 if (reg != BMP580_CHIP_ID && reg != BMP580_CHIP_ID_ALT)
2362 dev_warn(data->dev, "unexpected chip_id\n");
2364 ret = regmap_read(data->regmap, BMP580_REG_STATUS, &reg);
2365 if (ret) {
2366 dev_err(data->dev, "failed to read nvm status\n");
2367 return ret;
2370 /* Check nvm status */
2371 if (!(reg & BMP580_STATUS_NVM_RDY_MASK) || (reg & BMP580_STATUS_NVM_ERR_MASK)) {
2372 dev_err(data->dev, "nvm error on powerup sequence\n");
2373 return -EIO;
2376 /* Register nvmem device */
2377 return PTR_ERR_OR_ZERO(devm_nvmem_register(config.dev, &config));
2380 static const u8 bmp580_operation_mode[] = {
2381 [BMP280_SLEEP] = BMP580_MODE_SLEEP,
2382 [BMP280_FORCED] = BMP580_MODE_FORCED,
2383 [BMP280_NORMAL] = BMP580_MODE_NORMAL,
2386 static int bmp580_set_mode(struct bmp280_data *data, enum bmp280_op_mode mode)
2388 struct device *dev = data->dev;
2389 int ret;
2391 if (mode == BMP280_FORCED) {
2392 ret = regmap_set_bits(data->regmap, BMP580_REG_DSP_CONFIG,
2393 BMP580_DSP_IIR_FORCED_FLUSH);
2394 if (ret) {
2395 dev_err(dev, "Could not flush IIR filter constants.\n");
2396 return ret;
2400 ret = regmap_write_bits(data->regmap, BMP580_REG_ODR_CONFIG,
2401 BMP580_MODE_MASK,
2402 FIELD_PREP(BMP580_MODE_MASK,
2403 bmp580_operation_mode[mode]));
2404 if (ret) {
2405 dev_err(dev, "failed to write power control register.\n");
2406 return ret;
2409 data->op_mode = mode;
2411 return 0;
2414 static int bmp580_wait_conv(struct bmp280_data *data)
2417 * Taken from datasheet, Section 2 "Specification, Table 3 "Electrical
2418 * characteristics.
2420 static const int time_conv_press[] = {
2421 0, 1050, 1785, 3045, 5670, 10920, 21420, 42420,
2422 84420,
2424 static const int time_conv_temp[] = {
2425 0, 1050, 1105, 1575, 2205, 3465, 6090, 11340,
2426 21840,
2428 int meas_time_us;
2430 meas_time_us = 4 * USEC_PER_MSEC +
2431 time_conv_temp[data->oversampling_temp] +
2432 time_conv_press[data->oversampling_press];
2435 * Measurement time mentioned in Chapter 2, Table 4 of the datasheet.
2436 * The extra 4ms is the required mode change to start of measurement
2437 * time.
2439 fsleep(meas_time_us);
2441 return 0;
2444 static int bmp580_chip_config(struct bmp280_data *data)
2446 bool change = false, aux;
2447 unsigned int tmp;
2448 u8 reg_val;
2449 int ret;
2451 /* Sets sensor in standby mode */
2452 ret = regmap_update_bits(data->regmap, BMP580_REG_ODR_CONFIG,
2453 BMP580_MODE_MASK | BMP580_ODR_DEEPSLEEP_DIS,
2454 BMP580_ODR_DEEPSLEEP_DIS |
2455 FIELD_PREP(BMP580_MODE_MASK, BMP580_MODE_SLEEP));
2456 if (ret) {
2457 dev_err(data->dev, "failed to change sensor to standby mode\n");
2458 return ret;
2460 /* From datasheet's table 4: electrical characteristics */
2461 usleep_range(2500, 3000);
2463 /* Set default DSP mode settings */
2464 reg_val = FIELD_PREP(BMP580_DSP_COMP_MASK, BMP580_DSP_PRESS_TEMP_COMP_EN) |
2465 BMP580_DSP_SHDW_IIR_TEMP_EN | BMP580_DSP_SHDW_IIR_PRESS_EN;
2467 ret = regmap_update_bits(data->regmap, BMP580_REG_DSP_CONFIG,
2468 BMP580_DSP_COMP_MASK |
2469 BMP580_DSP_SHDW_IIR_TEMP_EN |
2470 BMP580_DSP_SHDW_IIR_PRESS_EN, reg_val);
2471 if (ret) {
2472 dev_err(data->dev, "failed to change DSP mode settings\n");
2473 return ret;
2476 /* Configure oversampling */
2477 reg_val = FIELD_PREP(BMP580_OSR_TEMP_MASK, data->oversampling_temp) |
2478 FIELD_PREP(BMP580_OSR_PRESS_MASK, data->oversampling_press) |
2479 BMP580_OSR_PRESS_EN;
2481 ret = regmap_update_bits_check(data->regmap, BMP580_REG_OSR_CONFIG,
2482 BMP580_OSR_TEMP_MASK |
2483 BMP580_OSR_PRESS_MASK |
2484 BMP580_OSR_PRESS_EN,
2485 reg_val, &aux);
2486 if (ret) {
2487 dev_err(data->dev, "failed to write oversampling register\n");
2488 return ret;
2490 change = change || aux;
2492 /* Configure output data rate */
2493 ret = regmap_update_bits_check(data->regmap, BMP580_REG_ODR_CONFIG, BMP580_ODR_MASK,
2494 FIELD_PREP(BMP580_ODR_MASK, data->sampling_freq),
2495 &aux);
2496 if (ret) {
2497 dev_err(data->dev, "failed to write ODR configuration register\n");
2498 return ret;
2500 change = change || aux;
2502 /* Set filter data */
2503 reg_val = FIELD_PREP(BMP580_DSP_IIR_PRESS_MASK, data->iir_filter_coeff) |
2504 FIELD_PREP(BMP580_DSP_IIR_TEMP_MASK, data->iir_filter_coeff);
2506 ret = regmap_update_bits(data->regmap, BMP580_REG_DSP_IIR,
2507 BMP580_DSP_IIR_PRESS_MASK | BMP580_DSP_IIR_TEMP_MASK,
2508 reg_val);
2509 if (ret) {
2510 dev_err(data->dev, "failed to write config register\n");
2511 return ret;
2514 if (change) {
2516 * Check if ODR and OSR settings are valid or we are
2517 * operating in a degraded mode.
2519 ret = regmap_read(data->regmap, BMP580_REG_EFF_OSR, &tmp);
2520 if (ret) {
2521 dev_err(data->dev,
2522 "error reading effective OSR register\n");
2523 return ret;
2525 if (!(tmp & BMP580_EFF_OSR_VALID_ODR)) {
2526 dev_warn(data->dev, "OSR and ODR incompatible settings detected\n");
2527 /* Set current OSR settings from data on effective OSR */
2528 data->oversampling_temp = FIELD_GET(BMP580_EFF_OSR_TEMP_MASK, tmp);
2529 data->oversampling_press = FIELD_GET(BMP580_EFF_OSR_PRESS_MASK, tmp);
2530 return -EINVAL;
2534 return 0;
2537 static int bmp580_data_rdy_trigger_set_state(struct iio_trigger *trig,
2538 bool state)
2540 struct bmp280_data *data = iio_trigger_get_drvdata(trig);
2541 int ret;
2543 guard(mutex)(&data->lock);
2545 ret = regmap_update_bits(data->regmap, BMP580_REG_INT_CONFIG,
2546 BMP580_INT_CONFIG_INT_EN,
2547 FIELD_PREP(BMP580_INT_CONFIG_INT_EN, !!state));
2548 if (ret)
2549 dev_err(data->dev,
2550 "Could not %s interrupt.\n", str_enable_disable(state));
2551 return ret;
2554 static const struct iio_trigger_ops bmp580_trigger_ops = {
2555 .set_trigger_state = &bmp580_data_rdy_trigger_set_state,
2558 static int bmp580_int_pin_config(struct bmp280_data *data)
2560 int pin_drive_cfg = FIELD_PREP(BMP580_INT_CONFIG_OPEN_DRAIN,
2561 data->trig_open_drain);
2562 int pin_level_cfg = FIELD_PREP(BMP580_INT_CONFIG_LEVEL,
2563 data->trig_active_high);
2564 int ret, int_pin_cfg = pin_drive_cfg | pin_level_cfg;
2566 ret = regmap_update_bits(data->regmap, BMP580_REG_INT_CONFIG,
2567 BMP580_INT_CONFIG_MASK, int_pin_cfg);
2568 if (ret) {
2569 dev_err(data->dev, "Could not set interrupt settings.\n");
2570 return ret;
2573 ret = regmap_set_bits(data->regmap, BMP580_REG_INT_SOURCE,
2574 BMP580_INT_SOURCE_DRDY);
2575 if (ret)
2576 dev_err(data->dev, "Could not set interrupt source.\n");
2578 return ret;
2581 static irqreturn_t bmp580_irq_thread_handler(int irq, void *p)
2583 struct iio_dev *indio_dev = p;
2584 struct bmp280_data *data = iio_priv(indio_dev);
2585 unsigned int int_ctrl;
2586 int ret;
2588 ret = regmap_read(data->regmap, BMP580_REG_INT_STATUS, &int_ctrl);
2589 if (ret)
2590 return IRQ_NONE;
2592 if (FIELD_GET(BMP580_INT_STATUS_DRDY_MASK, int_ctrl))
2593 iio_trigger_poll_nested(data->trig);
2595 return IRQ_HANDLED;
2598 static int bmp580_trigger_probe(struct iio_dev *indio_dev)
2600 return __bmp280_trigger_probe(indio_dev, &bmp580_trigger_ops,
2601 bmp580_int_pin_config,
2602 bmp580_irq_thread_handler);
2605 static irqreturn_t bmp580_trigger_handler(int irq, void *p)
2607 struct iio_poll_func *pf = p;
2608 struct iio_dev *indio_dev = pf->indio_dev;
2609 struct bmp280_data *data = iio_priv(indio_dev);
2610 int ret, offset;
2612 guard(mutex)(&data->lock);
2614 /* Burst read data registers */
2615 ret = regmap_bulk_read(data->regmap, BMP580_REG_TEMP_XLSB,
2616 data->buf, BMP280_BURST_READ_BYTES);
2617 if (ret) {
2618 dev_err(data->dev, "failed to burst read sensor data\n");
2619 goto out;
2622 offset = 0;
2624 /* Pressure calculations */
2625 memcpy(&data->sensor_data[offset], &data->buf[3], 3);
2627 offset += sizeof(s32);
2629 /* Temperature calculations */
2630 memcpy(&data->sensor_data[offset], &data->buf[0], 3);
2632 iio_push_to_buffers_with_timestamp(indio_dev, data->sensor_data,
2633 iio_get_time_ns(indio_dev));
2635 out:
2636 iio_trigger_notify_done(indio_dev->trig);
2638 return IRQ_HANDLED;
2641 static const int bmp580_oversampling_avail[] = { 1, 2, 4, 8, 16, 32, 64, 128 };
2642 static const u8 bmp580_chip_ids[] = { BMP580_CHIP_ID, BMP580_CHIP_ID_ALT };
2643 /* Instead of { 1000, 16 } we do this, to avoid overflow issues */
2644 static const int bmp580_temp_coeffs[] = { 125, 13 };
2645 static const int bmp580_press_coeffs[] = { 1, 64000};
2647 const struct bmp280_chip_info bmp580_chip_info = {
2648 .id_reg = BMP580_REG_CHIP_ID,
2649 .chip_id = bmp580_chip_ids,
2650 .num_chip_id = ARRAY_SIZE(bmp580_chip_ids),
2651 .regmap_config = &bmp580_regmap_config,
2652 .start_up_time = 2000,
2653 .channels = bmp580_channels,
2654 .num_channels = ARRAY_SIZE(bmp580_channels),
2655 .avail_scan_masks = bmp280_avail_scan_masks,
2657 .oversampling_temp_avail = bmp580_oversampling_avail,
2658 .num_oversampling_temp_avail = ARRAY_SIZE(bmp580_oversampling_avail),
2659 .oversampling_temp_default = ilog2(1),
2661 .oversampling_press_avail = bmp580_oversampling_avail,
2662 .num_oversampling_press_avail = ARRAY_SIZE(bmp580_oversampling_avail),
2663 .oversampling_press_default = ilog2(4),
2665 .sampling_freq_avail = bmp580_odr_table,
2666 .num_sampling_freq_avail = ARRAY_SIZE(bmp580_odr_table) * 2,
2667 .sampling_freq_default = BMP580_ODR_50HZ,
2669 .iir_filter_coeffs_avail = bmp380_iir_filter_coeffs_avail,
2670 .num_iir_filter_coeffs_avail = ARRAY_SIZE(bmp380_iir_filter_coeffs_avail),
2671 .iir_filter_coeff_default = 2,
2673 .temp_coeffs = bmp580_temp_coeffs,
2674 .temp_coeffs_type = IIO_VAL_FRACTIONAL_LOG2,
2675 .press_coeffs = bmp580_press_coeffs,
2676 .press_coeffs_type = IIO_VAL_FRACTIONAL,
2678 .chip_config = bmp580_chip_config,
2679 .read_temp = bmp580_read_temp,
2680 .read_press = bmp580_read_press,
2681 .set_mode = bmp580_set_mode,
2682 .wait_conv = bmp580_wait_conv,
2683 .preinit = bmp580_preinit,
2685 .trigger_probe = bmp580_trigger_probe,
2686 .trigger_handler = bmp580_trigger_handler,
2688 EXPORT_SYMBOL_NS(bmp580_chip_info, IIO_BMP280);
2690 static int bmp180_wait_for_eoc(struct bmp280_data *data, u8 ctrl_meas)
2692 static const int conversion_time_max[] = { 4500, 7500, 13500, 25500 };
2693 unsigned int delay_us;
2694 unsigned int ctrl;
2695 int ret;
2697 if (data->use_eoc)
2698 reinit_completion(&data->done);
2700 ret = regmap_write(data->regmap, BMP280_REG_CTRL_MEAS, ctrl_meas);
2701 if (ret) {
2702 dev_err(data->dev, "failed to write crtl_meas register\n");
2703 return ret;
2706 if (data->use_eoc) {
2708 * If we have a completion interrupt, use it, wait up to
2709 * 100ms. The longest conversion time listed is 76.5 ms for
2710 * advanced resolution mode.
2712 ret = wait_for_completion_timeout(&data->done,
2713 1 + msecs_to_jiffies(100));
2714 if (!ret)
2715 dev_err(data->dev, "timeout waiting for completion\n");
2716 } else {
2717 if (FIELD_GET(BMP180_MEAS_CTRL_MASK, ctrl_meas) == BMP180_MEAS_TEMP)
2718 delay_us = 4500;
2719 else
2720 delay_us =
2721 conversion_time_max[data->oversampling_press];
2723 usleep_range(delay_us, delay_us + 1000);
2726 ret = regmap_read(data->regmap, BMP280_REG_CTRL_MEAS, &ctrl);
2727 if (ret) {
2728 dev_err(data->dev, "failed to read ctrl_meas register\n");
2729 return ret;
2732 /* The value of this bit reset to "0" after conversion is complete */
2733 if (ctrl & BMP180_MEAS_SCO) {
2734 dev_err(data->dev, "conversion didn't complete\n");
2735 return -EIO;
2738 return 0;
2741 static int bmp180_read_temp_adc(struct bmp280_data *data, u32 *adc_temp)
2743 int ret;
2745 ret = bmp180_wait_for_eoc(data,
2746 FIELD_PREP(BMP180_MEAS_CTRL_MASK, BMP180_MEAS_TEMP) |
2747 BMP180_MEAS_SCO);
2748 if (ret)
2749 return ret;
2751 ret = regmap_bulk_read(data->regmap, BMP180_REG_OUT_MSB,
2752 &data->be16, sizeof(data->be16));
2753 if (ret) {
2754 dev_err(data->dev, "failed to read temperature\n");
2755 return ret;
2758 *adc_temp = be16_to_cpu(data->be16);
2760 return 0;
2763 static int bmp180_read_calib(struct bmp280_data *data)
2765 struct bmp180_calib *calib = &data->calib.bmp180;
2766 int ret;
2767 int i;
2769 ret = regmap_bulk_read(data->regmap, BMP180_REG_CALIB_START,
2770 data->bmp180_cal_buf, sizeof(data->bmp180_cal_buf));
2771 if (ret) {
2772 dev_err(data->dev, "failed to read calibration parameters\n");
2773 return ret;
2776 /* None of the words has the value 0 or 0xFFFF */
2777 for (i = 0; i < ARRAY_SIZE(data->bmp180_cal_buf); i++) {
2778 if (data->bmp180_cal_buf[i] == cpu_to_be16(0) ||
2779 data->bmp180_cal_buf[i] == cpu_to_be16(0xffff))
2780 return -EIO;
2783 /* Toss the calibration data into the entropy pool */
2784 add_device_randomness(data->bmp180_cal_buf,
2785 sizeof(data->bmp180_cal_buf));
2787 calib->AC1 = be16_to_cpu(data->bmp180_cal_buf[AC1]);
2788 calib->AC2 = be16_to_cpu(data->bmp180_cal_buf[AC2]);
2789 calib->AC3 = be16_to_cpu(data->bmp180_cal_buf[AC3]);
2790 calib->AC4 = be16_to_cpu(data->bmp180_cal_buf[AC4]);
2791 calib->AC5 = be16_to_cpu(data->bmp180_cal_buf[AC5]);
2792 calib->AC6 = be16_to_cpu(data->bmp180_cal_buf[AC6]);
2793 calib->B1 = be16_to_cpu(data->bmp180_cal_buf[B1]);
2794 calib->B2 = be16_to_cpu(data->bmp180_cal_buf[B2]);
2795 calib->MB = be16_to_cpu(data->bmp180_cal_buf[MB]);
2796 calib->MC = be16_to_cpu(data->bmp180_cal_buf[MC]);
2797 calib->MD = be16_to_cpu(data->bmp180_cal_buf[MD]);
2799 return 0;
2803 * Returns temperature in DegC, resolution is 0.1 DegC.
2804 * t_fine carries fine temperature as global value.
2806 * Taken from datasheet, Section 3.5, "Calculating pressure and temperature".
2809 static s32 bmp180_calc_t_fine(struct bmp280_data *data, u32 adc_temp)
2811 struct bmp180_calib *calib = &data->calib.bmp180;
2812 s32 x1, x2;
2814 x1 = ((((s32)adc_temp) - calib->AC6) * calib->AC5) >> 15;
2815 x2 = (calib->MC << 11) / (x1 + calib->MD);
2816 return x1 + x2; /* t_fine = x1 + x2; */
2819 static int bmp180_get_t_fine(struct bmp280_data *data, s32 *t_fine)
2821 s32 adc_temp;
2822 int ret;
2824 ret = bmp180_read_temp_adc(data, &adc_temp);
2825 if (ret)
2826 return ret;
2828 *t_fine = bmp180_calc_t_fine(data, adc_temp);
2830 return 0;
2833 static s32 bmp180_compensate_temp(struct bmp280_data *data, u32 adc_temp)
2835 return (bmp180_calc_t_fine(data, adc_temp) + 8) / 16;
2838 static int bmp180_read_temp(struct bmp280_data *data, s32 *comp_temp)
2840 u32 adc_temp;
2841 int ret;
2843 ret = bmp180_read_temp_adc(data, &adc_temp);
2844 if (ret)
2845 return ret;
2847 *comp_temp = bmp180_compensate_temp(data, adc_temp);
2849 return 0;
2852 static int bmp180_read_press_adc(struct bmp280_data *data, u32 *adc_press)
2854 u8 oss = data->oversampling_press;
2855 int ret;
2857 ret = bmp180_wait_for_eoc(data,
2858 FIELD_PREP(BMP180_MEAS_CTRL_MASK, BMP180_MEAS_PRESS) |
2859 FIELD_PREP(BMP180_OSRS_PRESS_MASK, oss) |
2860 BMP180_MEAS_SCO);
2861 if (ret)
2862 return ret;
2864 ret = regmap_bulk_read(data->regmap, BMP180_REG_OUT_MSB,
2865 data->buf, BMP280_NUM_PRESS_BYTES);
2866 if (ret) {
2867 dev_err(data->dev, "failed to read pressure\n");
2868 return ret;
2871 *adc_press = get_unaligned_be24(data->buf) >> (8 - oss);
2873 return 0;
2877 * Returns pressure in Pa, resolution is 1 Pa.
2879 * Taken from datasheet, Section 3.5, "Calculating pressure and temperature".
2881 static u32 bmp180_compensate_press(struct bmp280_data *data, u32 adc_press,
2882 s32 t_fine)
2884 struct bmp180_calib *calib = &data->calib.bmp180;
2885 s32 oss = data->oversampling_press;
2886 s32 x1, x2, x3, p;
2887 s32 b3, b6;
2888 u32 b4, b7;
2890 b6 = t_fine - 4000;
2891 x1 = (calib->B2 * (b6 * b6 >> 12)) >> 11;
2892 x2 = calib->AC2 * b6 >> 11;
2893 x3 = x1 + x2;
2894 b3 = ((((s32)calib->AC1 * 4 + x3) << oss) + 2) / 4;
2895 x1 = calib->AC3 * b6 >> 13;
2896 x2 = (calib->B1 * ((b6 * b6) >> 12)) >> 16;
2897 x3 = (x1 + x2 + 2) >> 2;
2898 b4 = calib->AC4 * (u32)(x3 + 32768) >> 15;
2899 b7 = (adc_press - b3) * (50000 >> oss);
2900 if (b7 < 0x80000000)
2901 p = (b7 * 2) / b4;
2902 else
2903 p = (b7 / b4) * 2;
2905 x1 = (p >> 8) * (p >> 8);
2906 x1 = (x1 * 3038) >> 16;
2907 x2 = (-7357 * p) >> 16;
2909 return p + ((x1 + x2 + 3791) >> 4);
2912 static int bmp180_read_press(struct bmp280_data *data, u32 *comp_press)
2914 u32 adc_press;
2915 s32 t_fine;
2916 int ret;
2918 ret = bmp180_get_t_fine(data, &t_fine);
2919 if (ret)
2920 return ret;
2922 ret = bmp180_read_press_adc(data, &adc_press);
2923 if (ret)
2924 return ret;
2926 *comp_press = bmp180_compensate_press(data, adc_press, t_fine);
2928 return 0;
2931 /* Keep compatibility with newer generations of the sensor */
2932 static int bmp180_set_mode(struct bmp280_data *data, enum bmp280_op_mode mode)
2934 return 0;
2937 /* Keep compatibility with newer generations of the sensor */
2938 static int bmp180_wait_conv(struct bmp280_data *data)
2940 return 0;
2943 /* Keep compatibility with newer generations of the sensor */
2944 static int bmp180_chip_config(struct bmp280_data *data)
2946 return 0;
2949 static irqreturn_t bmp180_trigger_handler(int irq, void *p)
2951 struct iio_poll_func *pf = p;
2952 struct iio_dev *indio_dev = pf->indio_dev;
2953 struct bmp280_data *data = iio_priv(indio_dev);
2954 int ret, comp_temp, comp_press;
2955 s32 *chans = (s32 *)data->sensor_data;
2957 guard(mutex)(&data->lock);
2959 ret = bmp180_read_temp(data, &comp_temp);
2960 if (ret)
2961 goto out;
2964 ret = bmp180_read_press(data, &comp_press);
2965 if (ret)
2966 goto out;
2968 chans[0] = comp_press;
2969 chans[1] = comp_temp;
2971 iio_push_to_buffers_with_timestamp(indio_dev, data->sensor_data,
2972 iio_get_time_ns(indio_dev));
2974 out:
2975 iio_trigger_notify_done(indio_dev->trig);
2977 return IRQ_HANDLED;
2980 static const int bmp180_oversampling_temp_avail[] = { 1 };
2981 static const int bmp180_oversampling_press_avail[] = { 1, 2, 4, 8 };
2982 static const u8 bmp180_chip_ids[] = { BMP180_CHIP_ID };
2983 static const int bmp180_temp_coeffs[] = { 100, 1 };
2984 static const int bmp180_press_coeffs[] = { 1, 1000 };
2986 const struct bmp280_chip_info bmp180_chip_info = {
2987 .id_reg = BMP280_REG_ID,
2988 .chip_id = bmp180_chip_ids,
2989 .num_chip_id = ARRAY_SIZE(bmp180_chip_ids),
2990 .regmap_config = &bmp180_regmap_config,
2991 .start_up_time = 2000,
2992 .channels = bmp280_channels,
2993 .num_channels = ARRAY_SIZE(bmp280_channels),
2994 .avail_scan_masks = bmp280_avail_scan_masks,
2996 .oversampling_temp_avail = bmp180_oversampling_temp_avail,
2997 .num_oversampling_temp_avail =
2998 ARRAY_SIZE(bmp180_oversampling_temp_avail),
2999 .oversampling_temp_default = 0,
3001 .oversampling_press_avail = bmp180_oversampling_press_avail,
3002 .num_oversampling_press_avail =
3003 ARRAY_SIZE(bmp180_oversampling_press_avail),
3004 .oversampling_press_default = BMP180_MEAS_PRESS_8X,
3006 .temp_coeffs = bmp180_temp_coeffs,
3007 .temp_coeffs_type = IIO_VAL_FRACTIONAL,
3008 .press_coeffs = bmp180_press_coeffs,
3009 .press_coeffs_type = IIO_VAL_FRACTIONAL,
3011 .chip_config = bmp180_chip_config,
3012 .read_temp = bmp180_read_temp,
3013 .read_press = bmp180_read_press,
3014 .read_calib = bmp180_read_calib,
3015 .set_mode = bmp180_set_mode,
3016 .wait_conv = bmp180_wait_conv,
3018 .trigger_handler = bmp180_trigger_handler,
3020 EXPORT_SYMBOL_NS(bmp180_chip_info, IIO_BMP280);
3022 static irqreturn_t bmp085_eoc_irq(int irq, void *d)
3024 struct bmp280_data *data = d;
3026 complete(&data->done);
3028 return IRQ_HANDLED;
3031 static int bmp085_trigger_probe(struct iio_dev *indio_dev)
3033 struct bmp280_data *data = iio_priv(indio_dev);
3034 struct device *dev = data->dev;
3035 unsigned long irq_trig;
3036 int ret, irq;
3038 irq = fwnode_irq_get(dev_fwnode(dev), 0);
3039 if (irq < 0)
3040 return dev_err_probe(dev, irq, "No interrupt found.\n");
3042 irq_trig = irq_get_trigger_type(irq);
3043 if (irq_trig != IRQF_TRIGGER_RISING) {
3044 dev_err(dev, "non-rising trigger given for EOC interrupt, trying to enforce it\n");
3045 irq_trig = IRQF_TRIGGER_RISING;
3048 init_completion(&data->done);
3050 ret = devm_request_irq(dev, irq, bmp085_eoc_irq, irq_trig,
3051 indio_dev->name, data);
3052 if (ret) {
3053 /* Bail out without IRQ but keep the driver in place */
3054 dev_err(dev, "unable to request DRDY IRQ\n");
3055 return 0;
3058 data->use_eoc = true;
3060 return 0;
3063 /* Identical to bmp180_chip_info + bmp085_trigger_probe */
3064 const struct bmp280_chip_info bmp085_chip_info = {
3065 .id_reg = BMP280_REG_ID,
3066 .chip_id = bmp180_chip_ids,
3067 .num_chip_id = ARRAY_SIZE(bmp180_chip_ids),
3068 .regmap_config = &bmp180_regmap_config,
3069 .start_up_time = 2000,
3070 .channels = bmp280_channels,
3071 .num_channels = ARRAY_SIZE(bmp280_channels),
3072 .avail_scan_masks = bmp280_avail_scan_masks,
3074 .oversampling_temp_avail = bmp180_oversampling_temp_avail,
3075 .num_oversampling_temp_avail =
3076 ARRAY_SIZE(bmp180_oversampling_temp_avail),
3077 .oversampling_temp_default = 0,
3079 .oversampling_press_avail = bmp180_oversampling_press_avail,
3080 .num_oversampling_press_avail =
3081 ARRAY_SIZE(bmp180_oversampling_press_avail),
3082 .oversampling_press_default = BMP180_MEAS_PRESS_8X,
3084 .temp_coeffs = bmp180_temp_coeffs,
3085 .temp_coeffs_type = IIO_VAL_FRACTIONAL,
3086 .press_coeffs = bmp180_press_coeffs,
3087 .press_coeffs_type = IIO_VAL_FRACTIONAL,
3089 .chip_config = bmp180_chip_config,
3090 .read_temp = bmp180_read_temp,
3091 .read_press = bmp180_read_press,
3092 .read_calib = bmp180_read_calib,
3093 .set_mode = bmp180_set_mode,
3094 .wait_conv = bmp180_wait_conv,
3096 .trigger_probe = bmp085_trigger_probe,
3097 .trigger_handler = bmp180_trigger_handler,
3099 EXPORT_SYMBOL_NS(bmp085_chip_info, IIO_BMP280);
3101 static int bmp280_buffer_preenable(struct iio_dev *indio_dev)
3103 struct bmp280_data *data = iio_priv(indio_dev);
3105 pm_runtime_get_sync(data->dev);
3106 data->chip_info->set_mode(data, BMP280_NORMAL);
3108 return 0;
3111 static int bmp280_buffer_postdisable(struct iio_dev *indio_dev)
3113 struct bmp280_data *data = iio_priv(indio_dev);
3115 pm_runtime_mark_last_busy(data->dev);
3116 pm_runtime_put_autosuspend(data->dev);
3118 return 0;
3121 static const struct iio_buffer_setup_ops bmp280_buffer_setup_ops = {
3122 .preenable = bmp280_buffer_preenable,
3123 .postdisable = bmp280_buffer_postdisable,
3126 static void bmp280_pm_disable(void *data)
3128 struct device *dev = data;
3130 pm_runtime_get_sync(dev);
3131 pm_runtime_put_noidle(dev);
3132 pm_runtime_disable(dev);
3135 static void bmp280_regulators_disable(void *data)
3137 struct regulator_bulk_data *supplies = data;
3139 regulator_bulk_disable(BMP280_NUM_SUPPLIES, supplies);
3142 int bmp280_common_probe(struct device *dev,
3143 struct regmap *regmap,
3144 const struct bmp280_chip_info *chip_info,
3145 const char *name,
3146 int irq)
3148 struct iio_dev *indio_dev;
3149 struct bmp280_data *data;
3150 struct gpio_desc *gpiod;
3151 unsigned int chip_id;
3152 unsigned int i;
3153 int ret;
3155 indio_dev = devm_iio_device_alloc(dev, sizeof(*data));
3156 if (!indio_dev)
3157 return -ENOMEM;
3159 data = iio_priv(indio_dev);
3160 mutex_init(&data->lock);
3161 data->dev = dev;
3163 indio_dev->name = name;
3164 indio_dev->info = &bmp280_info;
3165 indio_dev->modes = INDIO_DIRECT_MODE;
3167 data->chip_info = chip_info;
3169 /* Apply initial values from chip info structure */
3170 indio_dev->channels = chip_info->channels;
3171 indio_dev->num_channels = chip_info->num_channels;
3172 indio_dev->available_scan_masks = chip_info->avail_scan_masks;
3173 data->oversampling_press = chip_info->oversampling_press_default;
3174 data->oversampling_humid = chip_info->oversampling_humid_default;
3175 data->oversampling_temp = chip_info->oversampling_temp_default;
3176 data->iir_filter_coeff = chip_info->iir_filter_coeff_default;
3177 data->sampling_freq = chip_info->sampling_freq_default;
3178 data->start_up_time = chip_info->start_up_time;
3180 /* Bring up regulators */
3181 regulator_bulk_set_supply_names(data->supplies,
3182 bmp280_supply_names,
3183 BMP280_NUM_SUPPLIES);
3185 ret = devm_regulator_bulk_get(dev,
3186 BMP280_NUM_SUPPLIES, data->supplies);
3187 if (ret) {
3188 dev_err(dev, "failed to get regulators\n");
3189 return ret;
3192 ret = regulator_bulk_enable(BMP280_NUM_SUPPLIES, data->supplies);
3193 if (ret) {
3194 dev_err(dev, "failed to enable regulators\n");
3195 return ret;
3198 ret = devm_add_action_or_reset(dev, bmp280_regulators_disable,
3199 data->supplies);
3200 if (ret)
3201 return ret;
3203 /* Wait to make sure we started up properly */
3204 usleep_range(data->start_up_time, data->start_up_time + 100);
3206 /* Bring chip out of reset if there is an assigned GPIO line */
3207 gpiod = devm_gpiod_get_optional(dev, "reset", GPIOD_OUT_HIGH);
3208 /* Deassert the signal */
3209 if (gpiod) {
3210 dev_info(dev, "release reset\n");
3211 gpiod_set_value(gpiod, 0);
3214 data->regmap = regmap;
3216 ret = regmap_read(regmap, data->chip_info->id_reg, &chip_id);
3217 if (ret) {
3218 dev_err(data->dev, "failed to read chip id\n");
3219 return ret;
3222 for (i = 0; i < data->chip_info->num_chip_id; i++) {
3223 if (chip_id == data->chip_info->chip_id[i]) {
3224 dev_info(dev, "0x%x is a known chip id for %s\n", chip_id, name);
3225 break;
3229 if (i == data->chip_info->num_chip_id)
3230 dev_warn(dev, "bad chip id: 0x%x is not a known chip id\n", chip_id);
3232 if (data->chip_info->preinit) {
3233 ret = data->chip_info->preinit(data);
3234 if (ret)
3235 return dev_err_probe(data->dev, ret,
3236 "error running preinit tasks\n");
3239 ret = data->chip_info->chip_config(data);
3240 if (ret)
3241 return ret;
3243 dev_set_drvdata(dev, indio_dev);
3246 * Some chips have calibration parameters "programmed into the devices'
3247 * non-volatile memory during production". Let's read them out at probe
3248 * time once. They will not change.
3251 if (data->chip_info->read_calib) {
3252 ret = data->chip_info->read_calib(data);
3253 if (ret)
3254 return dev_err_probe(data->dev, ret,
3255 "failed to read calibration coefficients\n");
3258 ret = devm_iio_triggered_buffer_setup(data->dev, indio_dev,
3259 iio_pollfunc_store_time,
3260 data->chip_info->trigger_handler,
3261 &bmp280_buffer_setup_ops);
3262 if (ret)
3263 return dev_err_probe(data->dev, ret,
3264 "iio triggered buffer setup failed\n");
3267 * Attempt to grab an optional EOC IRQ - only the BMP085 has this
3268 * however as it happens, the BMP085 shares the chip ID of BMP180
3269 * so we look for an IRQ if we have that.
3271 if (irq > 0) {
3272 if (data->chip_info->trigger_probe)
3273 ret = data->chip_info->trigger_probe(indio_dev);
3274 if (ret)
3275 return ret;
3278 ret = data->chip_info->set_mode(data, BMP280_SLEEP);
3279 if (ret)
3280 return dev_err_probe(dev, ret, "Failed to set sleep mode\n");
3282 /* Enable runtime PM */
3283 pm_runtime_get_noresume(dev);
3284 pm_runtime_set_active(dev);
3285 pm_runtime_enable(dev);
3287 * Set autosuspend to two orders of magnitude larger than the
3288 * start-up time.
3290 pm_runtime_set_autosuspend_delay(dev, data->start_up_time / 10);
3291 pm_runtime_use_autosuspend(dev);
3292 pm_runtime_put(dev);
3294 ret = devm_add_action_or_reset(dev, bmp280_pm_disable, dev);
3295 if (ret)
3296 return ret;
3298 return devm_iio_device_register(dev, indio_dev);
3300 EXPORT_SYMBOL_NS(bmp280_common_probe, IIO_BMP280);
3302 static int bmp280_runtime_suspend(struct device *dev)
3304 struct iio_dev *indio_dev = dev_get_drvdata(dev);
3305 struct bmp280_data *data = iio_priv(indio_dev);
3307 data->chip_info->set_mode(data, BMP280_SLEEP);
3309 fsleep(data->start_up_time);
3310 return regulator_bulk_disable(BMP280_NUM_SUPPLIES, data->supplies);
3313 static int bmp280_runtime_resume(struct device *dev)
3315 struct iio_dev *indio_dev = dev_get_drvdata(dev);
3316 struct bmp280_data *data = iio_priv(indio_dev);
3317 int ret;
3319 ret = regulator_bulk_enable(BMP280_NUM_SUPPLIES, data->supplies);
3320 if (ret)
3321 return ret;
3323 usleep_range(data->start_up_time, data->start_up_time + 100);
3325 ret = data->chip_info->chip_config(data);
3326 if (ret)
3327 return ret;
3329 return data->chip_info->set_mode(data, data->op_mode);
3332 EXPORT_RUNTIME_DEV_PM_OPS(bmp280_dev_pm_ops, bmp280_runtime_suspend,
3333 bmp280_runtime_resume, NULL);
3335 MODULE_AUTHOR("Vlad Dogaru <vlad.dogaru@intel.com>");
3336 MODULE_DESCRIPTION("Driver for Bosch Sensortec BMP180/BMP280 pressure and temperature sensor");
3337 MODULE_LICENSE("GPL v2");