Skip to content
Snippets Groups Projects
bme680.h 8.16 KiB
Newer Older
  • Learn to ignore specific revisions
  • /**
     * 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	19 Jun 2018
     * @version	3.5.9
     * @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 "driver/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_ */
    /** @}*/