Changes in v5: [PATCH v5 1/3]: - Changed name of sensor to "co2-sensor" as it is already used by other chemical sensors. - Added reviewer tag. [PATCH v5 2/3]: - Removed unnecessary macro - Added reviewer tag [PATCH v5 3/3]: - Replaced pm_runtime_get_sync() with pm_runtime_resume_and_get() --- v4: https://lore.kernel.org/linux-iio/20241128193246.24572-1-vassilisamir@xxxxxxxxx/ Changes in v4: [PATCH v4 1/3]: - Changed description to include the move out of trivial devices. --- v3: https://lore.kernel.org/linux-iio/20241102131311.36210-1-vassilisamir@xxxxxxxxx/ Changes in v3: Removed applied patches 1,2,3,5,6,7,8 [PATCH v3 1/7]: - v2 4/13 - Set mode of sensor with enum variable and remove macros [PATCH v3 5/7]: - v2 11/13 - removed regulators from being required, adjusted commit message [PATCH v3 7/7]: - v2 13/13 - removed unecessary usage of runtime PM functions --- v2: https://lore.kernel.org/linux-iio/20241021195316.58911-1-vassilisamir@xxxxxxxxx/ Changes in v2: Generally, the patches were rearranged according to comments from Andy in previous version in order to be more consistent. The refactoring of the ambient temperature was dropped for now because it was a bit more complicated than I thought and this series is already heavy enough. [PATCH v2 01/13]: - New patch [PATCH v2 02/13]: - v1 1/13 - used "optimized" in commit message to not prompt for a fix. - added documentation of where this sleep comes from [PATCH v2 03/13]: - v1 2/13 - Fix indentation of array and removed extra whitespace. [PATCH v2 04/13]: - v1 5/13 - removed extra check inside the set_mode() function. [PATCH v2 06/13]: - v1 1/13 - removed indentation fixes which are fixed later since code is changed in those lines in later commits. [PATCH v2 09/13]: - v1 12/13 - removed unnecessary debug messages - Used struture instead of buffer to push data to userspace [PATCH v2 10/13]: - v1 13/13 - used better naming - made channel index to -1 [PATCH v2 11/13]: - v1 06/13 - removed device from trivial-devices [PATCH v2 12/13]: - v1 07/13 - use devm_regulator_bulk_get_enable() [PATCH v2 13/13]: - v1 08/13 - removed internal usage of dev structure - added missing header in both bme680_core.c and bme680.h - used devm_pm_runtime_enable --- v1: https://lore.kernel.org/linux-iio/20241010210030.33309-1-vassilisamir@xxxxxxxxx This patch series is continuing the work that started on [1] by improving some small issues of the driver in the commits 1,2,3. Commits 4,5 are refactorizing existing code. Commits 6,7,8 are adding DT, regulator and PM support. Commit 9 is refactorizing one macro to attribute. Commit 10,11,12 are refactorizing the read/compensate functions to become generic and add triggered buffer support. Finally, commit 13 adds support for an *output* channel of type IIO_CURRENT in order to preheat the plate that is used to measure the quality of the air. This and the previous series [1] started with the idea to add support for the new bme688 device but due to the structure of the driver I decided that it is better to restructure and improve some things before adding extra funcitonalities. [1]: https://lore.kernel.org/linux-iio/20240609233826.330516-1-vassilisamir@xxxxxxxxx Vasileios Amoiridis (3): Vasileios Amoiridis (3): dt-bindings: iio: bosch,bme680: Move from trivial-devices and add supplies iio: chemical: bme680: add regulators iio: chemical: bme680: add power management .../bindings/iio/chemical/bosch,bme680.yaml | 62 +++++++++ .../devicetree/bindings/trivial-devices.yaml | 2 - drivers/iio/chemical/bme680.h | 2 + drivers/iio/chemical/bme680_core.c | 125 +++++++++++++++++- drivers/iio/chemical/bme680_i2c.c | 1 + drivers/iio/chemical/bme680_spi.c | 1 + 6 files changed, 184 insertions(+), 9 deletions(-) create mode 100644 Documentation/devicetree/bindings/iio/chemical/bosch,bme680.yaml base-commit: a61ff7eac77e86de828fe28c4e42b8ae9ec2b195 -- 2.43.0