mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
171 lines
5.8 KiB
C
171 lines
5.8 KiB
C
|
/*
|
||
|
* Copyright (C) 2017 Freie Universität Berlin
|
||
|
*
|
||
|
* 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_bmx055 BMX055 9-axis sensor
|
||
|
* @ingroup drivers_sensors
|
||
|
* @brief Device driver for the Bosch BMX055 9-axis sensor
|
||
|
* @{
|
||
|
*
|
||
|
* @file
|
||
|
* @brief Device driver interface for the Bosch BMX055 9-axis sensor
|
||
|
*
|
||
|
* @note The current state of the driver only implements basic polling.
|
||
|
*
|
||
|
* @author Semjon Kerner <semjon.kerner@fu-berlin.de>
|
||
|
*/
|
||
|
|
||
|
#ifndef BMX055_H
|
||
|
#define BMX055_H
|
||
|
|
||
|
#include <stdint.h>
|
||
|
|
||
|
#include "periph/i2c.h"
|
||
|
#include "periph/gpio.h"
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
/**
|
||
|
* @name The sensors default I2C addresses
|
||
|
* @{
|
||
|
*/
|
||
|
#define BMX055_MAG_ADDR_DEFAULT (0x10U)
|
||
|
#define BMX055_ACC_ADDR_DEFAULT (0x18U)
|
||
|
#define BMX055_GYRO_ADDR_DEFAULT (0x68U)
|
||
|
/** @} */
|
||
|
|
||
|
/**
|
||
|
* @brief Status and error return codes
|
||
|
*/
|
||
|
enum {
|
||
|
BMX055_OK = 0, /**< exit without error */
|
||
|
BMX055_NOBUS = -1, /**< cannot connect to module on i2c bus */
|
||
|
BMX055_NODEV = -2, /**< cannot read any data from module */
|
||
|
BMX055_NOREAD = -3, /**< cannot read data from module */
|
||
|
BMX055_NOWRITE = -4, /**< cannot write data to module */
|
||
|
BMX055_NOTREADY = -5, /**< no new data ready for reading */
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* @brief Datarate for Magnetometer
|
||
|
*/
|
||
|
typedef enum {
|
||
|
BMX055_MAG_DRATE_DEFAULT = 0x0, /**< output data rate: 10 Hz */
|
||
|
BMX055_MAG_DRATE_02HZ = 0x1, /**< output data rate: 2 Hz */
|
||
|
BMX055_MAG_DRATE_06HZ = 0x2, /**< output data rate: 6 Hz */
|
||
|
BMX055_MAG_DRATE_08HZ = 0x3, /**< output data rate: 8 Hz*/
|
||
|
BMX055_MAG_DRATE_15HZ = 0x4, /**< output data rate: 15 Hz */
|
||
|
BMX055_MAG_DRATE_20HZ = 0x5, /**< output data rate: 20 Hz */
|
||
|
BMX055_MAG_DRATE_25HZ = 0x6, /**< output data rate: 25 Hz */
|
||
|
BMX055_MAG_DRATE_30HZ = 0x7, /**< output data rate: 30 Hz */
|
||
|
} bmx055_mag_rate_t;
|
||
|
|
||
|
/**
|
||
|
* @brief Range for Accelerometer
|
||
|
*/
|
||
|
typedef enum {
|
||
|
BMX055_ACC_RANGE_2G = 0x0, /**< range: 2g */
|
||
|
BMX055_ACC_RANGE_4G = 0x1, /**< range: 4g */
|
||
|
BMX055_ACC_RANGE_8G = 0x2, /**< range: 8g */
|
||
|
BMX055_ACC_RANGE_16G = 0x3, /**< range: 16g */
|
||
|
} bmx055_acc_range_t;
|
||
|
|
||
|
/**
|
||
|
* @brief Measurement scale for the gyro
|
||
|
*/
|
||
|
typedef enum {
|
||
|
BMX055_GYRO_SCALE_2000DPS = 0x0, /**< scale: 2000 degree per second */
|
||
|
BMX055_GYRO_SCALE_1000DPS = 0x1, /**< scale: 1000 degree per second */
|
||
|
BMX055_GYRO_SCALE_0500DPS = 0x2, /**< scale: 500 degree per second */
|
||
|
BMX055_GYRO_SCALE_0250DPS = 0x3, /**< scale: 250 degree per second */
|
||
|
BMX055_GYRO_SCALE_0125DPS = 0x4, /**< scale: 125 degree per second */
|
||
|
} bmx055_gyro_scale_t;
|
||
|
|
||
|
/**
|
||
|
* @brief Data structure holding the device parameters needed for initialization
|
||
|
*/
|
||
|
typedef struct {
|
||
|
i2c_t i2c; /**< I2C bus the device is connected to */
|
||
|
uint8_t addr_mag; /**< the magnetometer address on that bus */
|
||
|
uint8_t addr_acc; /**< the accelerometer address on that bus */
|
||
|
uint8_t addr_gyro; /**< the gyroscope address on that bus */
|
||
|
gpio_t int1_pin; /**< GPIO pin connected to the INT1 line */
|
||
|
gpio_t int2_pin; /**< GPIO pin connected to the INT2 line */
|
||
|
uint8_t mag_rate; /**< datarate of magnetometer */
|
||
|
uint8_t acc_range; /**< range of accelerometer */
|
||
|
uint8_t gyro_scale; /**< range of gyroscope*/
|
||
|
} bmx055_params_t;
|
||
|
|
||
|
/**
|
||
|
* @brief Device descriptor for BMX055 sensors
|
||
|
*/
|
||
|
typedef struct {
|
||
|
bmx055_params_t p; /**< Device initialization parameters*/
|
||
|
} bmx055_t;
|
||
|
|
||
|
/**
|
||
|
* @brief Initialize modules magnetometer, accelerometer, gyroscope
|
||
|
*
|
||
|
* @param[out] dev device descriptor of sensor to initialize
|
||
|
* @param[in] params default parameter values
|
||
|
*
|
||
|
* @return BMX055_OK on success
|
||
|
* @return BMX055_NOBUS if i2C connection can not be establish
|
||
|
* @return BMX055_NODEV if the register of a module can not be read
|
||
|
* @return BMX055_NOWRITE if a register can not be written
|
||
|
*/
|
||
|
int bmx055_init(bmx055_t *dev, const bmx055_params_t *params);
|
||
|
|
||
|
/**
|
||
|
* @brief Read magnetic field value in Gauss per second from magnetometer
|
||
|
*
|
||
|
* @param[in] dev device descriptor of magnetometer
|
||
|
* @param[out] data result vector in Gs per axis
|
||
|
*
|
||
|
* @return BMX055_OK on success
|
||
|
* @return BMX055_NOREAD if reading mag data is not possible
|
||
|
* @return BMX055_NOTRDY if no new data is available
|
||
|
*/
|
||
|
int bmx055_mag_read(const bmx055_t *dev, int16_t *data);
|
||
|
|
||
|
/**
|
||
|
* @brief Read acceleration value in g from accelerometer
|
||
|
*
|
||
|
* @param[in] dev device descriptor of accelerometer
|
||
|
* @param[out] data result vector in g per axis
|
||
|
*
|
||
|
* @return BMX055_OK on success
|
||
|
* @return BMX055_NOREAD if reading acc data is not possible
|
||
|
* @return BMX055_NOTRDY if no new data is available
|
||
|
*/
|
||
|
int bmx055_acc_read(const bmx055_t *dev, int16_t *data);
|
||
|
|
||
|
/**
|
||
|
* @brief Read angular speed value in degree per second from gyroscope
|
||
|
*
|
||
|
* @note The data of steady axis deviate from the expected values while
|
||
|
* moving the sensor in one of the other axis. Hence reading data for all axis
|
||
|
* at once may not always give the expected results.
|
||
|
*
|
||
|
* @param[in] dev device descriptor of gyroscope
|
||
|
* @param[out] data result vector in dps per axis
|
||
|
*
|
||
|
* @return BMX055_OK on success
|
||
|
* @return BMX055_NOREAD if reading gyro data is not possible
|
||
|
*/
|
||
|
int bmx055_gyro_read(const bmx055_t *dev, int16_t *data);
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif /* BMX055_H */
|
||
|
/** @} */
|