mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-12-26 06:53:52 +01:00
Merge pull request #7509 from PeterKietzmann/pr_lps331ap_saul_temp
drivers/lps331ap: add saul support for temperature sensor
This commit is contained in:
commit
db65120280
@ -23,17 +23,31 @@
|
||||
#include "saul.h"
|
||||
#include "lps331ap.h"
|
||||
|
||||
static int read(const void *dev, phydat_t *res)
|
||||
static int read_pres(const void *dev, phydat_t *res)
|
||||
{
|
||||
res->val[0] = (int16_t)lps331ap_read_pres((const lps331ap_t *)dev);
|
||||
memset(&(res->val[1]), 0, 2 * sizeof(int16_t));
|
||||
res->unit = UNIT_BAR;
|
||||
res->scale = -3;
|
||||
return 1;
|
||||
}
|
||||
|
||||
const saul_driver_t lps331ap_saul_driver = {
|
||||
.read = read,
|
||||
static int read_temp(const void *dev, phydat_t *res)
|
||||
{
|
||||
res->val[0] = (int16_t)(lps331ap_read_temp((const lps331ap_t *)dev) / 10);
|
||||
res->unit = UNIT_TEMP_C;
|
||||
/* above division by ten leads to °C * 10^-2*/
|
||||
res->scale = -2;
|
||||
return 1;
|
||||
}
|
||||
|
||||
const saul_driver_t lps331ap_saul_pres_driver = {
|
||||
.read = read_pres,
|
||||
.write = saul_notsup,
|
||||
.type = SAUL_SENSE_PRESS,
|
||||
};
|
||||
|
||||
const saul_driver_t lps331ap_saul_temp_driver = {
|
||||
.read = read_temp,
|
||||
.write = saul_notsup,
|
||||
.type = SAUL_SENSE_TEMP,
|
||||
};
|
||||
|
||||
@ -39,12 +39,13 @@ static lps331ap_t lps331ap_devs[LPS331AP_NUM];
|
||||
/**
|
||||
* @brief Memory for the SAUL registry entries
|
||||
*/
|
||||
static saul_reg_t saul_entries[LPS331AP_NUM];
|
||||
static saul_reg_t saul_entries[LPS331AP_NUM * 2];
|
||||
|
||||
/**
|
||||
* @brief Reference the driver struct
|
||||
*/
|
||||
extern saul_driver_t lps331ap_saul_driver;
|
||||
extern saul_driver_t lps331ap_saul_pres_driver;
|
||||
extern saul_driver_t lps331ap_saul_temp_driver;
|
||||
|
||||
|
||||
void auto_init_lps331ap(void)
|
||||
@ -62,8 +63,12 @@ void auto_init_lps331ap(void)
|
||||
|
||||
saul_entries[i].dev = &(lps331ap_devs[i]);
|
||||
saul_entries[i].name = lps331ap_saul_info[i].name;
|
||||
saul_entries[i].driver = &lps331ap_saul_driver;
|
||||
saul_entries[i].driver = &lps331ap_saul_pres_driver;
|
||||
saul_reg_add(&(saul_entries[i]));
|
||||
saul_entries[(i * 2) + 1].dev = &(lps331ap_devs[i]);
|
||||
saul_entries[(i * 2) + 1].name = lps331ap_saul_info[i].name;
|
||||
saul_entries[(i * 2) + 1].driver = &lps331ap_saul_temp_driver;
|
||||
saul_reg_add(&(saul_entries[(i * 2) + 1]));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user