2018-10-08 12:20:49 +02:00
|
|
|
/*
|
2022-06-28 13:36:57 +02:00
|
|
|
* Copyright (C) 2022 Gunar Schorcht
|
2018-10-08 12:20:49 +02:00
|
|
|
*
|
|
|
|
* 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
|
2022-06-28 13:36:57 +02:00
|
|
|
* @brief Architecture specific ADC definitions and functions for ESP32
|
|
|
|
*
|
|
|
|
* All ESP32x SoCs have two SAR ADC units each. However, these have
|
|
|
|
* functionalities as well as specific properties that vary between the
|
|
|
|
* ESP32x SoC and therefore require different handling for each ESP32x SoC.
|
|
|
|
* This is already taken into account in the high-level API of the ESP-IDF.
|
|
|
|
* To avoid having to reimplement these specifics and the different handling,
|
|
|
|
* the high-level API of the ESP-IDF is used directly for the ADC peripherals.
|
2018-10-08 12:20:49 +02:00
|
|
|
*
|
|
|
|
* @author Gunar Schorcht <gunar@schorcht.net>
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ADC_ARCH_H
|
|
|
|
#define ADC_ARCH_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "periph/adc.h"
|
2022-06-28 13:36:57 +02:00
|
|
|
#include "periph/gpio.h"
|
|
|
|
|
2023-03-27 01:34:36 +02:00
|
|
|
#include "driver/adc.h"
|
2022-06-28 13:36:57 +02:00
|
|
|
#include "hal/adc_types.h"
|
|
|
|
|
2018-10-08 12:20:49 +02:00
|
|
|
/**
|
|
|
|
* @brief Attenuations that can be set for ADC lines
|
2022-06-28 13:36:57 +02:00
|
|
|
*
|
|
|
|
* Event though ESP-IDF type `adc_atten_t` and `ADC_ATTEN_DB_*` are used
|
|
|
|
* now, the `adc_attenuation_t` type with constants `ADC_ATTENUATION_*_DB` are
|
|
|
|
* kept for compatibility.
|
2018-10-08 12:20:49 +02:00
|
|
|
*/
|
|
|
|
typedef enum {
|
2022-06-28 13:36:57 +02:00
|
|
|
ADC_ATTENUATION_0_DB = ADC_ATTEN_DB_0, /**< full-range is about 1.1 V (Vref) */
|
|
|
|
ADC_ATTENUATION_3_DB = ADC_ATTEN_DB_2_5, /**< full-range is about 1.5 V */
|
|
|
|
ADC_ATTENUATION_6_DB = ADC_ATTEN_DB_6, /**< full-range is about 2.2 V */
|
|
|
|
ADC_ATTENUATION_11_DB = ADC_ATTEN_DB_11, /**< full-range is about 3.3 V */
|
2018-10-08 12:20:49 +02:00
|
|
|
} adc_attenuation_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Set the attenuation for the ADC line. Default attenuation is 11 dB.
|
|
|
|
*
|
|
|
|
* For each ADC line, an attenuation of the input signal can be defined
|
|
|
|
* separately. This results in different full ranges of the measurable voltage
|
|
|
|
* at the input. The attenuation can be set to 0 dB, 3 dB, 6 dB and 11 dB,
|
|
|
|
* with 11 dB being the standard attenuation. Since an ADC input is measured
|
|
|
|
* against a reference voltage Vref of 1.1 V, approximately the following
|
|
|
|
* measurement ranges are given when using a corresponding attenuation:
|
|
|
|
*
|
|
|
|
* <center>
|
|
|
|
*
|
|
|
|
* Attenuation | Voltage Range | Symbol
|
|
|
|
* ----------------|-------------------|----------------------
|
2022-06-28 13:36:57 +02:00
|
|
|
* 0 dB | 0 ... 1.1V (Vref) | ADC_ATTEN_DB_0
|
|
|
|
* 2.5 dB | 0 ... 1.5V | ADC_ATTEN_DB_2_5
|
|
|
|
* 6 dB | 0 ... 2.2V | ADC_ATTEN_DB_6
|
|
|
|
* 11 dB (default) | 0 ... 3.3V | ADC_ATTEN_DB_11
|
2018-10-08 12:20:49 +02:00
|
|
|
*
|
|
|
|
* </center>
|
|
|
|
*
|
2022-06-28 13:36:57 +02:00
|
|
|
* @note: The reference voltage Vref can vary from ADC unit to ADC unit in
|
|
|
|
* the range of 1.0V and 1.2V. The Vref of a unit can be routed with
|
|
|
|
* function *adc_vref_to_gpio* to a GPIO pin.
|
2018-10-08 12:20:49 +02:00
|
|
|
*
|
|
|
|
* @param line ADC line for which the attenuation is set
|
|
|
|
* @param atten Attenuation, see type definition of *adc_attenuation_t
|
2022-06-28 13:36:57 +02:00
|
|
|
* @return 0 on success
|
|
|
|
* @return -1 on error
|
|
|
|
*/
|
|
|
|
int adc_set_attenuation(adc_t line, adc_atten_t atten);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Output reference voltage of a ADC line to GPIO n
|
|
|
|
*
|
|
|
|
* The Vref of the ADC unit of the given ADC line is routed to a GPIO pin n.
|
|
|
|
* This allows to measure the Vref used by the ADC unit to adjusted the
|
|
|
|
* results of the conversions accordingly.
|
|
|
|
*
|
|
|
|
* @note
|
|
|
|
* - The given GPIO must be a valid ADC channel of ADC2 unit.
|
|
|
|
* - For ESP32 and ESP32C3, the given ADC line has to be a channel of ADC2 unit.
|
|
|
|
*
|
|
|
|
* @param line ADC line for which Vref of its ADC unit is routed to the GPIO
|
|
|
|
* @param gpio GPIO to which Vref is routed (ADC2 channel GPIOs only)
|
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return -1 on error
|
2018-10-08 12:20:49 +02:00
|
|
|
*/
|
2022-06-28 13:36:57 +02:00
|
|
|
int adc_line_vref_to_gpio(adc_t line, gpio_t gpio);
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2022-07-18 07:33:33 +02:00
|
|
|
#if defined(CPU_FAM_ESP32)
|
2018-10-08 12:20:49 +02:00
|
|
|
/**
|
|
|
|
* @brief Output ADC reference voltage to GPIO25
|
|
|
|
*
|
2022-06-28 13:36:57 +02:00
|
|
|
* This function is deprecated and will be removed in future versions.
|
|
|
|
*
|
2018-10-08 12:20:49 +02:00
|
|
|
* @return 0 on success
|
|
|
|
* @return -1 on invalid ADC line
|
|
|
|
*/
|
2023-03-27 01:34:36 +02:00
|
|
|
static inline int adc_vref_to_gpio25(void)
|
2022-06-28 13:36:57 +02:00
|
|
|
{
|
2023-03-27 01:34:36 +02:00
|
|
|
return adc_vref_to_gpio(ADC_UNIT_2, GPIO25);
|
2022-06-28 13:36:57 +02:00
|
|
|
}
|
|
|
|
#endif
|
2018-10-08 12:20:49 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* ADC_ARCH_H */
|