/* * Copyright 2018 Otto-von-Guericke-Universität Magdeburg * * 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_sht1x * @{ * * @file * @brief SAUL adaption for SHT10/SHT11/SHT15 devices * * @author Marian Buschsieweke <marian.buschsieweke@ovgu.de> * * @} */ #include <errno.h> #include <stdio.h> #include <string.h> #include "phydat.h" #include "saul.h" #include "sht1x_defines.h" #include "sht1x.h" static int read(const sht1x_dev_t *dev, int16_t *temp, int16_t *hum) { for (int retries = 0; retries < SHT1X_SAUL_RETRIES; retries++) { switch (sht1x_read(dev, temp, hum)) { case 0: return 0; case -EBADMSG: puts("[sht1x] CRC"); continue; case -EPROTO: puts("[sht1x] Sensor did not acknowledge measurement command"); continue; case -ECANCELED: puts("[sht1x] Measurement times out"); /* falls through */ default: /* Other failure, cannot recover so giving up */ return -1; } } printf("[sht1x] Giving up after %i tries\n", SHT1X_SAUL_RETRIES); return -1; } static int read_temp(const void *dev, phydat_t *res) { if (read(dev, &res->val[0], NULL) == 0) { res->unit = UNIT_TEMP_C; res->scale = -2; return 1; } return -ECANCELED; } static int read_hum(const void *dev, phydat_t *res) { if (read(dev, NULL, &res->val[0]) == 0) { res->unit = UNIT_PERCENT; res->scale = -2; return 1; } return -ECANCELED; } const saul_driver_t sht1x_saul_temp_driver = { .read = read_temp, .write = saul_notsup, .type = SAUL_SENSE_TEMP }; const saul_driver_t sht1x_saul_hum_driver = { .read = read_hum, .write = saul_notsup, .type = SAUL_SENSE_HUM };