mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
158 lines
4.1 KiB
C
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 */
|
||
|
/** @} */
|