1b3bd85927
Bosch BME680 is a 4-in-1 sensor with temperature, pressure, humidity and gas sensing capability. It supports both I2C and SPI communication protocol for effective data communication. The device supports two modes: 1. Sleep mode 2. Forced mode The measurements only takes place when forced mode is triggered and a single TPHG cycle is performed by the sensor. The sensor automatically goes to sleep after afterwards. The device has various calibration constants/parameters programmed into devices' non-volatile memory(NVM) during production and can't be altered by the user. These constants are used in the compensation functions to get the required compensated readings along with the raw data. The compensation functions/algorithms are provided by Bosch Sensortec GmbH via their API[1]. As these don't change during the measurement cycle, therefore we read and store them at the probe. The default configs supplied by Bosch are also set at probe. 0-day tested with build success. GSoC-2018: https://summerofcode.withgoogle.com/projects/#6691473790074880 Mentor: Daniel Baluta [1] https://github.com/BoschSensortec/BME680_driver Datasheet: https://ae-bst.resource.bosch.com/media/_tech/media/datasheets/BST-BME680-DS001-00.pdf Note from Jonathan: The compensation functions are 'interesting' and could do with a tidy up in future. However, they work so we can leave that for another day. Cc: Daniel Baluta <daniel.baluta@nxp.com> Signed-off-by: Himanshu Jha <himanshujha199640@gmail.com> Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
13 lines
381 B
Makefile
13 lines
381 B
Makefile
#
|
|
# Makefile for IIO chemical sensors
|
|
#
|
|
|
|
# When adding new entries keep the list in alphabetical order
|
|
obj-$(CONFIG_ATLAS_PH_SENSOR) += atlas-ph-sensor.o
|
|
obj-$(CONFIG_BME680) += bme680_core.o
|
|
obj-$(CONFIG_BME680_I2C) += bme680_i2c.o
|
|
obj-$(CONFIG_BME680_SPI) += bme680_spi.o
|
|
obj-$(CONFIG_CCS811) += ccs811.o
|
|
obj-$(CONFIG_IAQCORE) += ams-iaq-core.o
|
|
obj-$(CONFIG_VZ89X) += vz89x.o
|