/** * Copyright (C) 2017 - 2018 Bosch Sensortec GmbH * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * Neither the name of the copyright holder nor the names of the * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL COPYRIGHT HOLDER * OR CONTRIBUTORS BE LIABLE FOR ANY * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, * OR CONSEQUENTIAL DAMAGES(INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN * ANY WAY OUT OF THE USE OF THIS * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE * * The information provided is believed to be accurate and reliable. * The copyright holder assumes no responsibility * for the consequences of use * of such information nor for any infringement of patents or * other rights of third parties which may result from its use. * No license is granted by implication or otherwise under any patent or * patent rights of the copyright holder. * * @file bme680.h * @date 30 Oct 2017 * @version 3.5.3 * @brief * */ /*! @file bme680.h @brief Sensor driver for BME680 sensor */ /*! * @defgroup BME680 SENSOR API * @{*/ #ifndef BME680_H_ #define BME680_H_ /*! CPP guard */ #ifdef __cplusplus extern "C" { #endif /* Header includes */ #include "bme680_defs.h" /* function prototype declarations */ /*! * @brief This API is the entry point. * It reads the chip-id and calibration data from the sensor. * * @param[in,out] dev : Structure instance of bme680_dev * * @return Result of API execution status * @retval zero -> Success / +ve value -> Warning / -ve value -> Error */ int8_t bme680_init(struct bme680_dev *dev); /*! * @brief This API writes the given data to the register address * of the sensor. * * @param[in] reg_addr : Register address from where the data to be written. * @param[in] reg_data : Pointer to data buffer which is to be written * in the sensor. * @param[in] len : No of bytes of data to write.. * @param[in] dev : Structure instance of bme680_dev. * * @return Result of API execution status * @retval zero -> Success / +ve value -> Warning / -ve value -> Error */ int8_t bme680_set_regs(const uint8_t *reg_addr, const uint8_t *reg_data, uint8_t len, struct bme680_dev *dev); /*! * @brief This API reads the data from the given register address of the sensor. * * @param[in] reg_addr : Register address from where the data to be read * @param[out] reg_data : Pointer to data buffer to store the read data. * @param[in] len : No of bytes of data to be read. * @param[in] dev : Structure instance of bme680_dev. * * @return Result of API execution status * @retval zero -> Success / +ve value -> Warning / -ve value -> Error */ int8_t bme680_get_regs(uint8_t reg_addr, uint8_t *reg_data, uint16_t len, struct bme680_dev *dev); /*! * @brief This API performs the soft reset of the sensor. * * @param[in] dev : Structure instance of bme680_dev. * * @return Result of API execution status * @retval zero -> Success / +ve value -> Warning / -ve value -> Error. */ int8_t bme680_soft_reset(struct bme680_dev *dev); /*! * @brief This API is used to set the power mode of the sensor. * * @param[in] dev : Structure instance of bme680_dev * @note : Pass the value to bme680_dev.power_mode structure variable. * * value | mode * -------------|------------------ * 0x00 | BME680_SLEEP_MODE * 0x01 | BME680_FORCED_MODE * * * @return Result of API execution status * @retval zero -> Success / +ve value -> Warning / -ve value -> Error */ int8_t bme680_set_sensor_mode(struct bme680_dev *dev); /*! * @brief This API is used to get the power mode of the sensor. * * @param[in] dev : Structure instance of bme680_dev * @note : bme680_dev.power_mode structure variable hold the power mode. * * value | mode * ---------|------------------ * 0x00 | BME680_SLEEP_MODE * 0x01 | BME680_FORCED_MODE * * @return Result of API execution status * @retval zero -> Success / +ve value -> Warning / -ve value -> Error */ int8_t bme680_get_sensor_mode(struct bme680_dev *dev); /*! * @brief This API is used to set the profile duration of the sensor. * * @param[in] dev : Structure instance of bme680_dev. * @param[in] duration : Duration of the measurement in ms. * * @return Nothing */ void bme680_set_profile_dur(uint16_t duration, struct bme680_dev *dev); /*! * @brief This API is used to get the profile duration of the sensor. * * @param[in] dev : Structure instance of bme680_dev. * @param[in] duration : Duration of the measurement in ms. * * @return Nothing */ void bme680_get_profile_dur(uint16_t *duration, const struct bme680_dev *dev); /*! * @brief This API reads the pressure, temperature and humidity and gas data * from the sensor, compensates the data and store it in the bme680_data * structure instance passed by the user. * * @param[out] data: Structure instance to hold the data. * @param[in] dev : Structure instance of bme680_dev. * * @return Result of API execution status * @retval zero -> Success / +ve value -> Warning / -ve value -> Error */ int8_t bme680_get_sensor_data(struct bme680_field_data *data, struct bme680_dev *dev); /*! * @brief This API is used to set the oversampling, filter and T,P,H, gas selection * settings in the sensor. * * @param[in] dev : Structure instance of bme680_dev. * @param[in] desired_settings : Variable used to select the settings which * are to be set in the sensor. * * Macros | Functionality *---------------------------------|---------------------------------------------- * BME680_OST_SEL | To set temperature oversampling. * BME680_OSP_SEL | To set pressure oversampling. * BME680_OSH_SEL | To set humidity oversampling. * BME680_GAS_MEAS_SEL | To set gas measurement setting. * BME680_FILTER_SEL | To set filter setting. * BME680_HCNTRL_SEL | To set humidity control setting. * BME680_RUN_GAS_SEL | To set run gas setting. * BME680_NBCONV_SEL | To set NB conversion setting. * BME680_GAS_SENSOR_SEL | To set all gas sensor related settings * * @note : Below are the macros to be used by the user for selecting the * desired settings. User can do OR operation of these macros for configuring * multiple settings. * * @return Result of API execution status * @retval zero -> Success / +ve value -> Warning / -ve value -> Error. */ int8_t bme680_set_sensor_settings(uint16_t desired_settings, struct bme680_dev *dev); /*! * @brief This API is used to get the oversampling, filter and T,P,H, gas selection * settings in the sensor. * * @param[in] dev : Structure instance of bme680_dev. * @param[in] desired_settings : Variable used to select the settings which * are to be get from the sensor. * * @return Result of API execution status * @retval zero -> Success / +ve value -> Warning / -ve value -> Error. */ int8_t bme680_get_sensor_settings(uint16_t desired_settings, struct bme680_dev *dev); #ifdef __cplusplus } #endif /* End of CPP guard */ #endif /* BME680_H_ */ /** @}*/