mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
drivers/bme680: add SAUL capabilities
This commit is contained in:
parent
1118f80180
commit
c4325e4d5e
@ -97,6 +97,9 @@ endif
|
|||||||
ifneq (,$(filter bme680_%,$(USEMODULE)))
|
ifneq (,$(filter bme680_%,$(USEMODULE)))
|
||||||
USEPKG += driver_bme680
|
USEPKG += driver_bme680
|
||||||
USEMODULE += bme680
|
USEMODULE += bme680
|
||||||
|
ifneq (,$(filter saul%,$(USEMODULE)))
|
||||||
|
USEMODULE += xtimer
|
||||||
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
||||||
ifneq (,$(filter bme680_i2c,$(USEMODULE)))
|
ifneq (,$(filter bme680_i2c,$(USEMODULE)))
|
||||||
|
210
drivers/bme680/bme680_saul.c
Normal file
210
drivers/bme680/bme680_saul.c
Normal file
@ -0,0 +1,210 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2020 Gunar Schorcht
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ingroup drivers_bme680
|
||||||
|
* @brief SAUL adaption for BME680 devices
|
||||||
|
* @author Gunar Schorcht <gunar@schorcht.net>
|
||||||
|
* @file
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <errno.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
#include "phydat.h"
|
||||||
|
#include "saul.h"
|
||||||
|
#include "bme680.h"
|
||||||
|
#include "bme680_params.h"
|
||||||
|
#include "xtimer.h"
|
||||||
|
|
||||||
|
extern bme680_t bme680_devs_saul[BME680_NUMOF];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Temperature, pressure, humidity and gas sensor values are fetched by separate
|
||||||
|
* saul functions. To avoid multiple waiting for the sensor, we read all sensor
|
||||||
|
* values once, if necessary, and store them in local variables to provide them
|
||||||
|
* in the separate saul read functions.
|
||||||
|
*/
|
||||||
|
static bool _temp_valid[BME680_NUMOF] = { false };
|
||||||
|
static bool _press_valid[BME680_NUMOF] = { false };
|
||||||
|
static bool _hum_valid[BME680_NUMOF] = { false };
|
||||||
|
static bool _gas_valid[BME680_NUMOF] = { false };
|
||||||
|
static int16_t _temp[BME680_NUMOF];
|
||||||
|
static int16_t _press[BME680_NUMOF];
|
||||||
|
static int16_t _hum[BME680_NUMOF];
|
||||||
|
static uint32_t _gas[BME680_NUMOF];
|
||||||
|
|
||||||
|
static unsigned _dev2index (const bme680_t *dev)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* returns the index of the device in bme680_devs_saul[] or BME680_NUMOF
|
||||||
|
* if not found
|
||||||
|
*/
|
||||||
|
for (unsigned i = 0; i < BME680_NUMOF; i++) {
|
||||||
|
if (dev == &bme680_devs_saul[i]) {
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return BME680_NUMOF;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int read(int dev)
|
||||||
|
{
|
||||||
|
/* measure and read sensor values */
|
||||||
|
int res;
|
||||||
|
if ((res = bme680_force_measurement(&bme680_devs_saul[dev])) != BME680_OK) {
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
int drt;
|
||||||
|
if ((drt = bme680_get_duration(&bme680_devs_saul[dev])) < 0) {
|
||||||
|
return BME680_INVALID;
|
||||||
|
}
|
||||||
|
xtimer_usleep(drt * US_PER_MS);
|
||||||
|
|
||||||
|
bme680_field_data_t data;
|
||||||
|
if ((res = bme680_get_data(&bme680_devs_saul[dev], &data)) != BME680_OK) {
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if MODULE_BME680_FP
|
||||||
|
_temp[dev] = data.temperature * 100;
|
||||||
|
_press[dev] = data.pressure / 100;
|
||||||
|
_hum[dev] = data.humidity * 100;
|
||||||
|
#else
|
||||||
|
_temp[dev] = data.temperature;
|
||||||
|
_press[dev] = data.pressure / 100;
|
||||||
|
_hum[dev] = data.humidity / 10;
|
||||||
|
#endif
|
||||||
|
_gas[dev] = (data.status & BME680_GASM_VALID_MSK) ? data.gas_resistance : 0;
|
||||||
|
|
||||||
|
/* mark sensor values as valid */
|
||||||
|
_temp_valid[dev] = true;
|
||||||
|
_press_valid[dev] = true;
|
||||||
|
_hum_valid[dev] = true;
|
||||||
|
_gas_valid[dev] = true;
|
||||||
|
return BME680_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int read_temp(const void *dev, phydat_t *data)
|
||||||
|
{
|
||||||
|
/* find the device index */
|
||||||
|
unsigned dev_index = _dev2index((const bme680_t *)dev);
|
||||||
|
if (dev_index == BME680_NUMOF) {
|
||||||
|
/* return with error if device index could not be found */
|
||||||
|
return -ECANCELED;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* either local variable is valid or fetching it was successful */
|
||||||
|
if (_temp_valid[dev_index] || read(dev_index) == BME680_OK) {
|
||||||
|
/* mark local variable as invalid */
|
||||||
|
_temp_valid[dev_index] = false;
|
||||||
|
|
||||||
|
data->val[0] = _temp[dev_index];
|
||||||
|
data->unit = UNIT_TEMP_C;
|
||||||
|
data->scale = -2;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return -ECANCELED;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int read_press(const void *dev, phydat_t *data)
|
||||||
|
{
|
||||||
|
/* find the device index */
|
||||||
|
unsigned dev_index = _dev2index((const bme680_t *)dev);
|
||||||
|
if (dev_index == BME680_NUMOF) {
|
||||||
|
/* return with error if device index could not be found */
|
||||||
|
return -ECANCELED;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* either local variable is valid or fetching it was successful */
|
||||||
|
if (_press_valid[dev_index] || read(dev_index) == BME680_OK) {
|
||||||
|
/* mark local variable as invalid */
|
||||||
|
_press_valid[dev_index] = false;
|
||||||
|
|
||||||
|
data->val[0] = _press[dev_index];
|
||||||
|
data->unit = UNIT_PA;
|
||||||
|
data->scale = 2;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return -ECANCELED;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int read_hum(const void *dev, phydat_t *data)
|
||||||
|
{
|
||||||
|
/* find the device index */
|
||||||
|
unsigned dev_index = _dev2index((const bme680_t *)dev);
|
||||||
|
if (dev_index == BME680_NUMOF) {
|
||||||
|
/* return with error if device index could not be found */
|
||||||
|
return -ECANCELED;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* either local variable is valid or fetching it was successful */
|
||||||
|
if (_hum_valid[dev_index] || read(dev_index) == BME680_OK) {
|
||||||
|
/* mark local variable as invalid */
|
||||||
|
_hum_valid[dev_index] = false;
|
||||||
|
|
||||||
|
data->val[0] = _hum[dev_index];
|
||||||
|
data->unit = UNIT_PERCENT;
|
||||||
|
data->scale = -2;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return -ECANCELED;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int read_gas(const void *dev, phydat_t *data)
|
||||||
|
{
|
||||||
|
/* find the device index */
|
||||||
|
unsigned dev_index = _dev2index((const bme680_t *)dev);
|
||||||
|
if (dev_index == BME680_NUMOF) {
|
||||||
|
/* return with error if device index could not be found */
|
||||||
|
return -ECANCELED;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* either local variable is valid or fetching it was successful */
|
||||||
|
if (_gas_valid[dev_index] || read(dev_index) == BME680_OK) {
|
||||||
|
/* mark local variable as invalid */
|
||||||
|
_gas_valid[dev_index] = false;
|
||||||
|
|
||||||
|
if (_gas[dev_index] > INT16_MAX) {
|
||||||
|
data->val[0] = _gas[dev_index] / 1000;
|
||||||
|
data->scale = 3;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
data->val[0] = _gas[dev_index];
|
||||||
|
data->scale = 0;
|
||||||
|
}
|
||||||
|
data->unit = UNIT_OHM;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return -ECANCELED;
|
||||||
|
}
|
||||||
|
|
||||||
|
const saul_driver_t bme680_saul_driver_temperature = {
|
||||||
|
.read = read_temp,
|
||||||
|
.write = saul_notsup,
|
||||||
|
.type = SAUL_SENSE_TEMP
|
||||||
|
};
|
||||||
|
|
||||||
|
const saul_driver_t bme680_saul_driver_pressure = {
|
||||||
|
.read = read_press,
|
||||||
|
.write = saul_notsup,
|
||||||
|
.type = SAUL_SENSE_PRESS
|
||||||
|
};
|
||||||
|
|
||||||
|
const saul_driver_t bme680_saul_driver_humidity = {
|
||||||
|
.read = read_hum,
|
||||||
|
.write = saul_notsup,
|
||||||
|
.type = SAUL_SENSE_HUM
|
||||||
|
};
|
||||||
|
|
||||||
|
const saul_driver_t bme680_saul_driver_gas = {
|
||||||
|
.read = read_gas,
|
||||||
|
.write = saul_notsup,
|
||||||
|
.type = SAUL_SENSE_GAS
|
||||||
|
};
|
@ -23,6 +23,7 @@
|
|||||||
|
|
||||||
#include "board.h"
|
#include "board.h"
|
||||||
#include "bme680.h"
|
#include "bme680.h"
|
||||||
|
#include "saul_reg.h"
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
@ -96,6 +97,18 @@ extern "C" {
|
|||||||
.intf.spi.dev = BME680_PARAM_SPI_DEV, \
|
.intf.spi.dev = BME680_PARAM_SPI_DEV, \
|
||||||
.intf.spi.nss_pin = BME680_PARAM_SPI_NSS_PIN, \
|
.intf.spi.nss_pin = BME680_PARAM_SPI_NSS_PIN, \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Default SAUL meta information
|
||||||
|
*/
|
||||||
|
#ifndef BME680_SAUL_INFO
|
||||||
|
#if MODULE_BME680_I2C && MODULE_BME680_SPI
|
||||||
|
#define BME680_SAUL_INFO { .name = "bme680:0" }, \
|
||||||
|
{ .name = "bme680:1" },
|
||||||
|
#else /* MODULE_BME680_I2C && MODULE_BME680_SPI */
|
||||||
|
#define BME680_SAUL_INFO { .name = "bme680" }
|
||||||
|
#endif /* MODULE_BME680_I2C && MODULE_BME680_SPI */
|
||||||
|
#endif /* BME680_SAUL_INFO */
|
||||||
/**@}*/
|
/**@}*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -111,6 +124,14 @@ static const bme680_params_t bme680_params[] =
|
|||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Additional meta information to keep in the SAUL registry
|
||||||
|
*/
|
||||||
|
static const saul_reg_info_t bme680_saul_info[] =
|
||||||
|
{
|
||||||
|
BME680_SAUL_INFO
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief The number of configured sensors
|
* @brief The number of configured sensors
|
||||||
*/
|
*/
|
||||||
|
Loading…
Reference in New Issue
Block a user