1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-15 19:52:45 +01:00
RIOT/drivers/include/bmp180.h

143 lines
4.3 KiB
C
Raw Normal View History

2016-03-14 16:03:36 +01:00
/*
* Copyright (C) 2016 Inria
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* @defgroup drivers_bmp180 BMP180 temperature and pressure sensor
2016-03-14 16:03:36 +01:00
* @ingroup drivers_sensors
* @ingroup drivers_saul
* @brief Device driver interface for the BMP180 sensor
*
* This driver provides @ref drivers_saul capabilities.
2016-03-14 16:03:36 +01:00
* @{
*
* @file
* @brief Device driver interface for the BMP180 sensor.
*
* @author Alexandre Abadie <alexandre.abadie@inria.fr>
*/
#ifndef BMP180_H
#define BMP180_H
2016-03-14 16:03:36 +01:00
2016-05-29 19:19:20 +02:00
#include "saul.h"
2016-03-14 16:03:36 +01:00
#include "periph/i2c.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
2017-08-29 18:00:46 +02:00
* @brief Oversampling modes
2016-03-14 16:03:36 +01:00
*/
2017-03-20 09:58:13 +01:00
typedef enum {
BMP180_ULTRALOWPOWER = 0,
BMP180_STANDARD,
BMP180_HIGHRES,
BMP180_ULTRAHIGHRES
} bmp180_oversampling_mode_t;
2016-03-14 16:03:36 +01:00
/**
2017-08-29 18:00:46 +02:00
* @brief Calibration struct for the BMP180 sensor
2016-03-14 16:03:36 +01:00
*/
typedef struct {
2017-03-20 09:58:13 +01:00
int16_t ac1; /**< ac1 coefficient */
int16_t ac2; /**< ac2 coefficient */
int16_t ac3; /**< ac3 coefficient */
int16_t b1; /**< b1 coefficient */
int16_t b2; /**< b2 coefficient */
int16_t mb; /**< mb coefficient */
int16_t mc; /**< mc coefficient */
int16_t md; /**< md coefficient */
uint16_t ac4; /**< ac4 coefficient */
uint16_t ac5; /**< ac5 coefficient */
uint16_t ac6; /**< ac6 coefficient */
2016-03-14 16:03:36 +01:00
} bmp180_calibration_t;
/**
2017-08-29 18:00:46 +02:00
* @brief Device initialization parameters
2016-03-14 16:03:36 +01:00
*/
typedef struct {
2017-03-20 09:58:13 +01:00
i2c_t i2c_dev; /**< I2C device which is used */
uint8_t i2c_addr; /**< I2C address */
bmp180_oversampling_mode_t oversampling; /**< Oversampling mode */
} bmp180_params_t;
2016-05-29 19:19:20 +02:00
/**
2017-08-29 18:00:46 +02:00
* @brief Device descriptor for the BMP180 sensor
2016-05-29 19:19:20 +02:00
*/
typedef struct {
2017-03-20 09:58:13 +01:00
bmp180_params_t params; /**< Device initialization parameters */
bmp180_calibration_t calibration; /**< Device calibration */
} bmp180_t;
2016-05-29 19:19:20 +02:00
/**
2017-03-20 09:58:13 +01:00
* @brief Status and error return codes
2016-05-29 19:19:20 +02:00
*/
2017-03-20 09:58:13 +01:00
enum {
BMP180_OK = 0, /**< everything was fine */
BMP180_ERR_NODEV, /**< did not detect BMP180 */
BMP180_ERR_NOCAL, /**< error when reading calibration values */
};
2016-05-29 19:19:20 +02:00
2016-03-14 16:03:36 +01:00
/**
2017-08-29 18:00:46 +02:00
* @brief Initialize the given BMP180 device
2016-03-14 16:03:36 +01:00
*
* @param[out] dev Initialized device descriptor of BMP180 device
2017-03-20 09:58:13 +01:00
* @param[in] params Initialization parameters
2016-03-14 16:03:36 +01:00
*
2017-03-20 09:58:13 +01:00
* @return BMP180_OK on success
* @return -BMP180_ERR_NODEV if not a BMP180 at given address
* @return -BMP180_ERR_NOCAL if an error occurred when reading calibration values
2016-03-14 16:03:36 +01:00
*/
2017-03-20 09:58:13 +01:00
int bmp180_init(bmp180_t *dev, const bmp180_params_t *params);
2016-03-14 16:03:36 +01:00
/**
2017-08-29 18:00:46 +02:00
* @brief Read temperature value from the given BMP180 device, returned in d°C
2016-03-14 16:03:36 +01:00
*
* @param[in] dev Device descriptor of BMP180 device to read from
*
2017-03-20 09:58:13 +01:00
* @return Temperature in d°C
2016-03-14 16:03:36 +01:00
*/
2017-06-20 17:32:45 +02:00
int16_t bmp180_read_temperature(const bmp180_t *dev);
2016-03-14 16:03:36 +01:00
/**
2017-08-29 18:00:46 +02:00
* @brief Read pressure value from the given BMP180 device, returned in Pa
2016-03-14 16:03:36 +01:00
*
* @param[in] dev Device descriptor of BMP180 device to read from
*
2017-03-20 09:58:13 +01:00
* @return Pressure in Pa
2016-03-14 16:03:36 +01:00
*/
2017-06-20 17:32:45 +02:00
uint32_t bmp180_read_pressure(const bmp180_t *dev);
2016-03-14 16:03:36 +01:00
/**
2017-08-29 18:00:46 +02:00
* @brief Compute altitude, returned in m.
2016-03-14 16:03:36 +01:00
*
* @param[in] dev Device descriptor of BMP180 device to read from
* @param[in] pressure_0 The pressure at sea level in Pa
*
2017-03-20 09:58:13 +01:00
* @return Altitude in m
2016-03-14 16:03:36 +01:00
*/
2017-06-20 17:32:45 +02:00
int16_t bmp180_altitude(const bmp180_t *dev, uint32_t pressure_0);
2016-03-14 16:03:36 +01:00
/**
2017-08-29 18:00:46 +02:00
* @brief Compute pressure at sea level, returned in Pa.
2016-03-14 16:03:36 +01:00
*
* @param[in] dev Device descriptor of BMP180 device to read from
* @param[in] altitude Altitude in m
*
2017-03-20 09:58:13 +01:00
* @return Pressure at sea level in Pa
2016-03-14 16:03:36 +01:00
*/
2017-06-20 17:32:45 +02:00
uint32_t bmp180_sealevel_pressure(const bmp180_t *dev, int16_t altitude);
2016-03-14 16:03:36 +01:00
#ifdef __cplusplus
}
#endif
#endif /* BMP180_H */
2016-03-14 16:03:36 +01:00
/** @} */