From 66a7a0a0656231046ffe7068cf67abee6c953620 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fabian=20H=C3=BC=C3=9Fler?= Date: Sat, 19 Feb 2022 17:26:21 +0100 Subject: [PATCH] drivers/periph: add VBAT interface --- drivers/include/periph/vbat.h | 72 +++++++++++++++++++++++++++++++++++ 1 file changed, 72 insertions(+) create mode 100644 drivers/include/periph/vbat.h diff --git a/drivers/include/periph/vbat.h b/drivers/include/periph/vbat.h new file mode 100644 index 0000000000..4156ae192c --- /dev/null +++ b/drivers/include/periph/vbat.h @@ -0,0 +1,72 @@ +/* + * Copyright (C) 2022 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. + */ + +/** + * @defgroup drivers_periph_vbat backup battery monitoring + * @ingroup drivers_periph + * @brief Driver to monitor the internal backup battery status + * + * The backup battery must be connected with the VBAT pin and GND. + * On most development boards you will have to remove a solder bridge + * that connects VDD with VBAT. The battery is used to retain the backup domain + * register and RTC register content while power (VDD) is off. + * + * The actual driver is implemented as a CPU feature. + * A board that supports + * backup battery monitoring via ADC, must `#define VBAT_ADC ADC_LINE(x)`, + * where `x` is the index of the internal VBAT ADC line in `adc_config[]` + * in periph_conf.h. + * + * @{ + * + * @file + * @brief Interface of backup battery (VBAT) monitoring + * + * @author Fabian Hüßler + */ + +#ifndef PERIPH_VBAT_H +#define PERIPH_VBAT_H + +#include +#include + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @brief Initialize backup battery monitoring + * + * @retval != 0: Failure + * @retval 0: Success + */ +int vbat_init(void); + +/** + * @brief Sample backup battery + * + * @return Backup battery load in mV + */ +int32_t vbat_sample_mv(void); + +/** + * @brief Sample the backup battery and compare the result with + * the minimum value required to power the backup domain + * + * @retval true: empty + * @retval false: not empty + */ +bool vbat_is_empty(void); + +#ifdef __cplusplus +} +#endif + +#endif /* PERIPH_VBAT_H */ +/** @} */