1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/cpu/esp32/include/adc_ctrl.h

101 lines
2.6 KiB
C
Raw Normal View History

/*
* Copyright (C) 2019 Gunar Schorcht
*
* 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 cpu_esp32
* @{
*
* @file
* @brief ADC controller functions used by ADC and DAC peripherals
*
* @author Gunar Schorcht <gunar@schorcht.net>
* @}
*/
#ifndef ADC_CTRL_H
#define ADC_CTRL_H
#ifdef __cplusplus
extern "C" {
#endif
#include "periph/gpio.h"
/**
* @brief ADC controllers
*/
enum {
ADC1_CTRL, /**< ADC1 controller */
ADC2_CTRL /**< ADC2 controller */
};
/**
* @brief RTC IO pin type (does not correspond to RTC gpio num order)
*/
enum {
RTCIO_TOUCH0 = 0, /**< touch sensor 0 */
RTCIO_TOUCH1, /**< touch sensor 1 */
RTCIO_TOUCH2, /**< touch sensor 2 */
RTCIO_TOUCH3, /**< touch sensor 3 */
RTCIO_TOUCH4, /**< touch sensor 4 */
RTCIO_TOUCH5, /**< touch sensor 5 */
RTCIO_TOUCH6, /**< touch sensor 6 */
RTCIO_TOUCH7, /**< touch sensor 7 */
RTCIO_TOUCH8, /**< touch sensor 8, 32K_XP */
RTCIO_TOUCH9, /**< touch sensor 9, 32K_XN */
RTCIO_ADC_ADC1, /**< VDET_1 */
RTCIO_ADC_ADC2, /**< VDET_2 */
RTCIO_SENSOR_SENSE1, /**< SENSOR_VP */
RTCIO_SENSOR_SENSE2, /**< SENSOR_CAPP */
RTCIO_SENSOR_SENSE3, /**< SENSOR_CAPN */
RTCIO_SENSOR_SENSE4, /**< SENSOR_VN */
RTCIO_DAC1, /**< DAC output */
RTCIO_DAC2, /**< DAC output */
RTCIO_NA, /**< RTC pad not available */
};
/**
* @brief ADC pin hardware information type (for internal use only)
*/
struct _adc_hw_t {
gpio_t gpio; /**< GPIO */
uint8_t rtc_gpio; /**< corresponding RTC GPIO */
uint8_t adc_ctrl; /**< ADC controller */
uint8_t adc_channel; /**< channel of ADC controller */
char* pad_name; /**< symbolic name of pad */
};
/**
* @brief RTC hardware map
*
* The index corresponds to RTC pin type _rtcio_pin_t (Table 19 in Technical
* Reference)
*/
extern const struct _adc_hw_t _adc_hw[];
/**
* @brief Configure sleep mode for an GPIO pin if the pin is a RTCIO pin
* @param pin GPIO pin
* @param mode active in sleep mode if true
* @param input as input if true, as output otherwise
* @return 0 success
* @return -1 on invalid pin
*/
int rtcio_config_sleep_mode (gpio_t pin, bool mode, bool input);
#ifdef __cplusplus
}
#endif
#endif /* ADC_CTRL_H */