2017-10-26 10:21:12 +02:00
|
|
|
/*
|
|
|
|
* Copyright 2017, RWTH Aachen. All rights reserved.
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2022-02-25 17:17:11 +01:00
|
|
|
* @defgroup drivers_shtcx SHTCX Temperature and humidity sensor
|
2017-10-26 10:21:12 +02:00
|
|
|
* @ingroup drivers_sensors
|
|
|
|
* @ingroup drivers_saul
|
2022-02-25 17:17:11 +01:00
|
|
|
* @brief Driver for the Sensirion SHTCX sensor.
|
|
|
|
*
|
|
|
|
* @{
|
2017-10-26 10:21:12 +02:00
|
|
|
*
|
|
|
|
* @file
|
2022-02-25 17:17:11 +01:00
|
|
|
* @brief Device driver interface for the SHTCX Temperature and humidity sensor
|
2017-10-26 10:21:12 +02:00
|
|
|
*
|
|
|
|
* @author Steffen Robertz <steffen.robertz@rwth-aachen.de>
|
|
|
|
* @author Josua Arndt <jarndt@ias.rwth-aachen.de>
|
|
|
|
*/
|
|
|
|
|
2022-02-25 17:17:11 +01:00
|
|
|
#ifndef SHTCX_H
|
|
|
|
#define SHTCX_H
|
2017-10-26 10:21:12 +02:00
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "saul.h"
|
|
|
|
|
|
|
|
#include "periph/i2c.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
2022-02-25 17:17:11 +01:00
|
|
|
* @brief SHTCX Default Address
|
2017-10-26 10:21:12 +02:00
|
|
|
*
|
|
|
|
*/
|
2022-02-25 17:17:11 +01:00
|
|
|
#ifndef SHTCX_I2C_ADDRESS
|
|
|
|
#define SHTCX_I2C_ADDRESS (0x70)
|
2017-10-26 10:21:12 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief settings struct with all relevant parameters
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
i2c_t i2c_dev; /**< I2C bus descriptor. */
|
|
|
|
uint8_t i2c_addr; /**< I2C address of the sensor. */
|
2022-02-25 17:17:11 +01:00
|
|
|
} shtcx_params_t;
|
2017-10-26 10:21:12 +02:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
2022-02-25 17:17:11 +01:00
|
|
|
* @brief device descriptor for the SHTCX
|
2017-10-26 10:21:12 +02:00
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
typedef struct {
|
2022-02-25 17:17:11 +01:00
|
|
|
shtcx_params_t params; /**< Parameters struct with all settings set. */
|
|
|
|
} shtcx_t;
|
2017-10-26 10:21:12 +02:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
enum {
|
2022-02-25 17:17:11 +01:00
|
|
|
SHTCX_OK, /**< Success, no error */
|
|
|
|
SHTCX_ERROR_BUS, /**< I2C bus error */
|
|
|
|
SHTCX_ERROR_CRC, /**< CRC error */
|
|
|
|
SHTCX_ERROR /**< General error */
|
2017-10-26 10:21:12 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initializes the sensor and I2C.
|
|
|
|
*
|
|
|
|
* @param[in] dev I2C device descriptor.
|
2022-02-25 17:17:11 +01:00
|
|
|
* @param[in] params SHTCX parameters to be used.
|
2017-10-26 10:21:12 +02:00
|
|
|
*
|
2022-02-25 17:17:11 +01:00
|
|
|
* @return SHTCX_OK on a working initialization.
|
|
|
|
* @return SHTCX_ERROR_BUS Reading I2C failed.
|
|
|
|
* @return SHTCX_ERROR_CRC Wrong ID.
|
2017-10-26 10:21:12 +02:00
|
|
|
*/
|
2022-02-25 17:17:11 +01:00
|
|
|
int8_t shtcx_init(shtcx_t* const dev, const shtcx_params_t* params);
|
2017-10-26 10:21:12 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Reads all register values from the device.
|
2023-10-16 12:17:48 +02:00
|
|
|
* @details The values as raw data will be saved into received.
|
2017-10-26 10:21:12 +02:00
|
|
|
*
|
|
|
|
* @param[in] dev The I2C device descriptor.
|
|
|
|
* @param[in] rel_humidity Humidity in centi %.
|
|
|
|
* @param[in] temperature Temperature in centi °C.
|
|
|
|
*
|
2022-02-25 17:17:11 +01:00
|
|
|
* @return SHTCX_OK if a measurement completed.
|
|
|
|
* @return SHTCX_ERROR_BUS reading I2C failed.
|
|
|
|
* @return SHTCX_ERROR_CRC on checksum error.
|
2017-10-26 10:21:12 +02:00
|
|
|
*/
|
2022-02-25 17:17:11 +01:00
|
|
|
int8_t shtcx_read(const shtcx_t *dev, uint16_t *rel_humidity, int16_t *temperature);
|
2017-10-26 10:21:12 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Reads the ID and saves it in the device descriptor
|
|
|
|
*
|
2022-02-25 17:17:11 +01:00
|
|
|
* @details When working correctly ID should equal
|
|
|
|
* xxxx'xxxx'xx00'0111 where x is unspecified.
|
2017-10-26 10:21:12 +02:00
|
|
|
*
|
|
|
|
* @param[in] dev The I2C device descriptor.
|
|
|
|
* @param[in] id ID of the device.
|
|
|
|
*
|
2022-02-25 17:17:11 +01:00
|
|
|
* @return SHTCX_OK on everything done.
|
|
|
|
* @return SHTCX_ERROR_BUS on error.
|
2017-10-26 10:21:12 +02:00
|
|
|
*/
|
2022-02-25 17:17:11 +01:00
|
|
|
int8_t shtcx_id(const shtcx_t *dev, uint16_t *id);
|
2017-10-26 10:21:12 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Resets sensor
|
|
|
|
*
|
|
|
|
* This will reset all internal state machines and reload calibration data from the memory.
|
|
|
|
*
|
|
|
|
* @param[in] dev The I2C device descriptor.
|
|
|
|
*
|
2022-02-25 17:17:11 +01:00
|
|
|
* @return SHTCX_OK on everything done.
|
|
|
|
* @return SHTCX_ERROR_BUS on error.
|
2017-10-26 10:21:12 +02:00
|
|
|
*/
|
2022-02-25 17:17:11 +01:00
|
|
|
int8_t shtcx_reset(const shtcx_t *dev);
|
2017-10-26 10:21:12 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2022-02-25 17:17:11 +01:00
|
|
|
#endif /* SHTCX_H */
|
2017-10-26 10:21:12 +02:00
|
|
|
/** @} */
|