1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/drivers/include/mhz19.h

158 lines
4.1 KiB
C

/*
* Copyright (C) 2018 Koen Zandberg <koen@bergzand.net>
* Copyright (C) 2018 Beduino Master Projekt - University of Bremen
* Copyright (C) 2020 Bas Stottelaar <basstottelaar@gmail.com>
*
* 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.
*/
/**
* @defgroup drivers_mhz19 MH-Z19 CO2 sensor
* @ingroup drivers_sensors
*
* @brief MH-Z19 CO2 sensor driver
*
* ## Description
*
* The MH-Z19 is a CO2 sensor. Measurements are provided in parts per million
* (ppm) over UART and PWM. The ppm value ranges from 0 (theoretically) to
* 2000 or 5000, depending on the sensor settings.
*
* In UART mode, additional commands are available to configure the sensor.
*
* Note that the sensor requires considerable time before accurate measurements
* are provided.
*
* @{
*
* @file
* @brief Interface definition for the MH-Z19 CO2 sensor driver.
*
* @author Koen Zandberg <koen@bergzand.net>
* @author Christian Manal <manal@uni-bremen.de>
* @author Bas Stottelaar <basstottelaar@gmail.com>
*/
#ifndef MHZ19_H
#define MHZ19_H
#include <stdbool.h>
#include "saul.h"
#ifdef MODULE_MHZ19_UART
#include "periph/uart.h"
#include "mhz19_internals.h"
#include "mutex.h"
#endif /* MODULE_MHZ19_UART */
#ifdef MODULE_MHZ19_PWM
#include "periph/gpio.h"
#endif /* MODULE_MHZ19_PWM */
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief Status and error return codes
*/
enum {
MHZ19_OK = 0, /**< everything was fine */
MHZ19_ERR_INIT = -1, /**< error initializing the device */
MHZ19_ERR_TIMEOUT = -2, /**< timeout on retrieving sensor data */
MHZ19_ERR_CHECKSUM = -3, /**< checksum failure on received data */
};
#ifdef MODULE_MHZ19_UART
/**
* @brief Device initialization parameters
*/
typedef struct {
uart_t uart; /**< UART device that sensor is connected to */
bool auto_calibration; /** enable or disable auto calibration */
} mhz19_params_t;
/**
* @brief Device descriptor for a MH-Z19 device
*/
typedef struct {
const mhz19_params_t *params; /**< device parameters */
mutex_t mutex; /**< protect against simulaneous access */
mutex_t sync; /**< transfer complete or timeout sync */
uint8_t idx; /**< rx buffer index */
uint8_t rxmem[MHZ19_BUF_SIZE]; /**< rx buffer */
} mhz19_t;
#endif /* MODULE_MHZ19_UART */
#ifdef MODULE_MHZ19_PWM
/**
* @brief Device initialization parameters
*/
typedef struct {
gpio_t pin; /**< Pin the sensor is connected to */
} mhz19_params_t;
/**
* @brief Device descriptor for a mhz19 driver
*/
typedef struct {
gpio_t pin; /**< Pin the sensor is connected to */
} mhz19_t;
#endif /* MODULE_MHZ19_PWM */
/**
* @brief Export SAUL endpoint
*/
extern const saul_driver_t mhz19_ppm_saul_driver;
/**
* @brief Initialize a MH-Z19 device
*
* @param[out] dev device descriptor
* @param[in] params MH-Z19 initialization struct
*
* @return MHZ19_OK
* @return MHZ19_ERR_INIT
*/
int mhz19_init(mhz19_t *dev, const mhz19_params_t *params);
/**
* @brief Get measured CO2 ppm value
*
* @param[in] dev device descriptor
* @param[out] ppm int16_t buffer where CO2 measurement will be
* written to, in ppm
*
* @return MHZ19_OK
* @return MHZ19_ERR_TIMEOUT
* @return MHZ19_ERR_CHECKSUM
*/
int mhz19_get_ppm(mhz19_t *dev, int16_t *ppm);
#ifdef MODULE_MHZ19_UART
/**
* @brief Enable or disable auto base calibration
*
* @param[in] dev device descriptor
* @param[in] enable true to enable, false to disable
*/
void mhz19_set_auto_calibration(mhz19_t *dev, bool enable);
/**
* @brief Calibrate zero point
*
* @param[in] dev device descriptor
*/
void mhz19_calibrate_zero_point(mhz19_t *dev);
#endif
#ifdef __cplusplus
}
#endif
#endif /* MHZ19_H */
/** @} */