[PATCH v5 0/3] iio: chemical bme680: 2nd round of cleanup

From: Vasileios Amoiridis
Date: Mon Dec 02 2024 - 14:24:01 EST


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