2018-04-18 23:44:50 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2018 UC Berkeley
|
|
|
|
*
|
|
|
|
* 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_fxos8700 FXOS8700 3-axis accelerometer/magnetometer
|
|
|
|
* @ingroup drivers_sensors
|
2018-06-12 10:35:56 +02:00
|
|
|
* @ingroup drivers_saul
|
2018-04-18 23:44:50 +02:00
|
|
|
* @brief Driver for the FXOS8700 3-axis accelerometer/magnetometer
|
|
|
|
*
|
|
|
|
* The connection between the MCU and the FXOS8700 is based on the
|
|
|
|
* I2C-interface.
|
|
|
|
*
|
2018-06-12 10:35:56 +02:00
|
|
|
* This driver provides @ref drivers_saul capabilities.
|
2018-04-18 23:44:50 +02:00
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Interface definition for the FXOS8700 sensor driver
|
|
|
|
*
|
|
|
|
* @author Michael Andersen <m.andersen@cs.berkeley.edu>
|
|
|
|
* @author Hyung-Sin Kim <hs.kim@cs.berkeley.edu>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef FXOS8700_H
|
|
|
|
#define FXOS8700_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "periph/i2c.h"
|
|
|
|
#include "fxos8700_regs.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2020-04-01 11:23:44 +02:00
|
|
|
/**
|
|
|
|
* @defgroup drivers_fxos8700_config FXOS8700 accelerometer/magnetometer driver compile configuration
|
2020-04-10 12:20:41 +02:00
|
|
|
* @ingroup config_drivers_sensors
|
2020-04-01 11:23:44 +02:00
|
|
|
* @{
|
|
|
|
*/
|
2018-04-18 23:44:50 +02:00
|
|
|
/**
|
|
|
|
* @brief Default raw value mode for accelerator
|
|
|
|
*
|
2020-04-21 12:41:26 +02:00
|
|
|
* Set this to 1 to return raw ADC readings. Otherwise measurements
|
|
|
|
* will be converted to mg.
|
2018-04-18 23:44:50 +02:00
|
|
|
*/
|
2020-04-21 12:41:26 +02:00
|
|
|
#ifdef DOXYGEN
|
|
|
|
#define CONFIG_FXOS8700_USE_ACC_RAW_VALUES
|
2018-04-18 23:44:50 +02:00
|
|
|
#endif
|
2020-04-01 11:23:44 +02:00
|
|
|
/** @} */
|
2020-04-10 12:20:41 +02:00
|
|
|
|
2018-04-18 23:44:50 +02:00
|
|
|
/**
|
|
|
|
* @brief FXOS8700 specific return values
|
|
|
|
*/
|
|
|
|
enum {
|
|
|
|
FXOS8700_OK = 0, /**< everything went as expected */
|
|
|
|
FXOS8700_ADDRERR = -1, /**< no FXOS8700 device found on the bus */
|
|
|
|
FXOS8700_NOBUS = -2, /**< errors while initializing the I2C bus */
|
|
|
|
FXOS8700_NODEV = -3, /**< no FXOS8700 device found on the bus */
|
|
|
|
FXOS8700_BUSERR = -4 /**< error during I2C communication */
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Parameters needed for device initialization
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
i2c_t i2c; /**< I2C device that sensor is connected to */
|
|
|
|
uint8_t addr; /**< I2C address of this particular sensor */
|
|
|
|
uint8_t acc_range; /**< Accelerator full-scale range */
|
|
|
|
uint32_t renew_interval; /**< Interval for cache renewal */
|
|
|
|
} fxos8700_params_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Individual 3-axis measurement
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
int16_t x; /**< x axis of 3-axis measurement */
|
|
|
|
int16_t y; /**< y axis of 3-axis measurement */
|
|
|
|
int16_t z; /**< z axis of 3-axis measurement */
|
|
|
|
} fxos8700_measurement_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Device descriptor for a FXOS8700 device
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
uint8_t config; /**< sensor configuration including active mode */
|
|
|
|
fxos8700_measurement_t acc_cached; /**< cached 3-axis acceleration */
|
|
|
|
fxos8700_measurement_t mag_cached; /**< cached 3-axis magnetic field */
|
|
|
|
uint32_t last_read_time; /**< last time when cached data was refreshed */
|
|
|
|
fxos8700_params_t p; /**< configuration parameters */
|
|
|
|
} fxos8700_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initialize an FXOS8700 device
|
|
|
|
*
|
|
|
|
* @param[out] dev device descriptor
|
|
|
|
* @param[in] params parameters for device
|
|
|
|
*
|
|
|
|
* @return FXOS8700_OK on success
|
|
|
|
* @return FXOS8700_NOBUS on I2C initialization error
|
|
|
|
* @return FXOS8700_BUSERR on I2C communication error
|
|
|
|
* @return FXOS8700_ADDRERR on invalid address
|
|
|
|
* @return FXOS8700_NODEV if no FXOS8700 device found on bus
|
|
|
|
*/
|
|
|
|
int fxos8700_init(fxos8700_t* dev, const fxos8700_params_t* params);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Convenience function for turning on the FXOS8700
|
|
|
|
*
|
|
|
|
* This function will trigger a new conversion, wait for the conversion to be
|
|
|
|
* finished and the get the results from the device.
|
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of sensor
|
|
|
|
*
|
|
|
|
* @return FXOS8700_OK on success
|
|
|
|
* @return FXOS8700_BUSERR on I2C communication failures
|
|
|
|
*/
|
|
|
|
int fxos8700_set_active(const fxos8700_t* dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Convenience function for turning off the FXOS8700
|
|
|
|
*
|
|
|
|
* This function will trigger a new conversion, wait for the conversion to be
|
|
|
|
* finished and the get the results from the device.
|
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of sensor
|
|
|
|
*
|
|
|
|
* @return FXOS8700_OK on success
|
|
|
|
* @return FXOS8700_BUSERR on I2C communication failures
|
|
|
|
*/
|
|
|
|
int fxos8700_set_idle(const fxos8700_t* dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Convenience function for reading acceleration and magnetic field
|
|
|
|
*
|
|
|
|
* This function will trigger a new conversion, wait for the conversion to be
|
|
|
|
* finished and the get the results from the device.
|
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of sensor
|
|
|
|
* @param[out] acc 3-axis acceleration [in milli grativy acceleration (mg) ]
|
|
|
|
* @param[out] mag 3-axis magnetic field [in degree milli Gauss (mGs) ]
|
|
|
|
*
|
|
|
|
* @return FXOS8700_OK on success
|
|
|
|
* @return FXOS8700_BUSERR on I2C communication failures
|
|
|
|
*/
|
|
|
|
int fxos8700_read(const fxos8700_t* dev, fxos8700_measurement_t* acc, fxos8700_measurement_t* mag);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Extended read function including caching capability
|
|
|
|
*
|
|
|
|
* This function will return cached values if they are within the sampling
|
|
|
|
* period (FXOS8700_RENEW_INTERVAL), or will trigger a new conversion, wait for
|
|
|
|
* the conversion to be finished and the get the results from the device.
|
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of sensor
|
|
|
|
* @param[out] acc 3-axis acceleration [in milli grativy acceleration (mg) ]
|
|
|
|
* @param[out] mag 3-axis magnetic field [in degree milli Gauss (mGs) ]
|
|
|
|
*
|
|
|
|
* @return FXOS8700_OK on success
|
|
|
|
* @return FXOS8700_BUSERR on I2C communication failures
|
|
|
|
*/
|
|
|
|
int fxos8700_read_cached(const void* dev, fxos8700_measurement_t* acc, fxos8700_measurement_t* mag);
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* FXOS8700_H */
|
|
|
|
/** @} */
|