2016-01-21 22:33:02 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2016 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup drivers_dht
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief SAUL adaption for DHT devices
|
|
|
|
*
|
|
|
|
* The values exported to SAUL for DHT devices are buffered, meaning that new
|
|
|
|
* values will only be read from the device, if the buffered values are older
|
|
|
|
* then 1 second (being exactly the maximum sampling time for DHT devices).
|
|
|
|
*
|
|
|
|
* This buffering does further introduce a coupling between both SAUL endpoints,
|
|
|
|
* meaning that if you read from both endpoints after each other, both values
|
|
|
|
* are from the same sensor reading.
|
|
|
|
*
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include "saul.h"
|
|
|
|
#include "dht.h"
|
|
|
|
#include "xtimer.h"
|
|
|
|
|
|
|
|
#define DHT_SAUL_HOLD_TIME (1000 * 1000U) /* 1s */
|
|
|
|
|
|
|
|
static int16_t temp, hum;
|
|
|
|
static uint32_t last = 0;
|
|
|
|
|
2017-06-26 16:00:34 +02:00
|
|
|
static int check_and_read(const void *dev, phydat_t *res, int16_t *val, uint8_t unit)
|
2016-01-21 22:33:02 +01:00
|
|
|
{
|
2016-07-05 21:32:44 +02:00
|
|
|
uint32_t now = xtimer_now_usec();
|
2016-01-21 22:33:02 +01:00
|
|
|
|
|
|
|
if ((now - last) > DHT_SAUL_HOLD_TIME) {
|
2017-06-26 16:00:34 +02:00
|
|
|
dht_read((const dht_t *)dev, &temp, &hum);
|
2016-01-21 22:33:02 +01:00
|
|
|
last = now;
|
|
|
|
}
|
|
|
|
|
|
|
|
res->val[0] = *val;
|
2019-01-07 21:59:25 +01:00
|
|
|
res->val[1] = 0;
|
|
|
|
res->val[2] = 0;
|
2016-01-21 22:33:02 +01:00
|
|
|
res->unit = unit;
|
|
|
|
res->scale = -1;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2017-06-26 16:00:34 +02:00
|
|
|
static int read_temp(const void *dev, phydat_t *res)
|
2016-01-21 22:33:02 +01:00
|
|
|
{
|
|
|
|
return check_and_read(dev, res, &temp, UNIT_TEMP_C);
|
|
|
|
}
|
|
|
|
|
2017-06-26 16:00:34 +02:00
|
|
|
static int read_hum(const void *dev, phydat_t *res)
|
2016-01-21 22:33:02 +01:00
|
|
|
{
|
|
|
|
return check_and_read(dev, res, &hum, UNIT_PERCENT);
|
|
|
|
}
|
|
|
|
|
|
|
|
const saul_driver_t dht_temp_saul_driver = {
|
|
|
|
.read = read_temp,
|
|
|
|
.write = saul_notsup,
|
|
|
|
.type = SAUL_SENSE_TEMP
|
|
|
|
};
|
|
|
|
|
|
|
|
const saul_driver_t dht_hum_saul_driver = {
|
|
|
|
.read = read_hum,
|
|
|
|
.write = saul_notsup,
|
|
|
|
.type = SAUL_SENSE_HUM
|
|
|
|
};
|