/* * Copyright (C) 2018 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 CPU specific definitions and functions for peripheral handling * * @author Gunar Schorcht */ #ifndef PERIPH_CPU_H #define PERIPH_CPU_H #include #include "sdkconfig.h" #include "hal/ledc_types.h" #include "hal/spi_types.h" #include "soc/ledc_struct.h" #include "soc/periph_defs.h" #include "soc/soc_caps.h" #ifdef __cplusplus extern "C" { #endif /** * @name Power management configuration * @{ */ #define PROVIDES_PM_SET_LOWEST #define PROVIDES_PM_RESTART #define PROVIDES_PM_OFF #define PROVIDES_PM_LAYERED_OFF /** * @brief Number of usable low power modes */ #define PM_NUM_MODES (3U) /** * @name Power modes * @{ */ #define ESP_PM_MODEM_SLEEP (2U) #define ESP_PM_LIGHT_SLEEP (1U) #define ESP_PM_DEEP_SLEEP (0U) /** @} */ /** @} */ /** * @brief Length of the CPU_ID in octets */ #define CPUID_LEN (6U) /** * @name GPIO configuration * @{ */ /** * @brief Override the default gpio_t type definition * * This is required here to have gpio_t defined in this file. * @{ */ #define HAVE_GPIO_T typedef unsigned int gpio_t; /** @} */ /** * @brief Definition of a fitting UNDEF value * @{ */ #define GPIO_UNDEF (0xffffffff) /** @} */ /** * @brief Define a CPU specific GPIO pin generator macro * @{ */ #define GPIO_PIN(x, y) ((x & 0) | y) /** @} */ /** * @brief Available GPIO ports on ESP32 * @{ */ #define PORT_GPIO (0) /** @} */ /** * @brief Define CPU specific number of GPIO pins * @{ */ #define GPIO_PIN_NUMOF (40) /** @} */ #ifndef DOXYGEN /** * @brief Override mode flank selection values * * @{ */ #define HAVE_GPIO_FLANK_T typedef enum { GPIO_NONE = 0, GPIO_RISING = 1, /**< emit interrupt on rising flank */ GPIO_FALLING = 2, /**< emit interrupt on falling flank */ GPIO_BOTH = 3, /**< emit interrupt on both flanks */ GPIO_LOW = 4, /**< emit interrupt on low level */ GPIO_HIGH = 5 /**< emit interrupt on low level */ } gpio_flank_t; /** @} */ /** * @brief Override GPIO modes * * @{ */ #define HAVE_GPIO_MODE_T typedef enum { GPIO_IN, /**< input */ GPIO_IN_PD, /**< input with pull-down */ GPIO_IN_PU, /**< input with pull-up */ GPIO_OUT, /**< output */ GPIO_OD, /**< open-drain output */ GPIO_OD_PU, /**< open-drain output with pull-up */ GPIO_IN_OUT, /**< input and output */ GPIO_IN_OD, /**< input and open-drain output */ GPIO_IN_OD_PU /**< input and open-drain output */ } gpio_mode_t; /** @} */ #endif /* ndef DOXYGEN */ /** @} */ /** * @name Predefined GPIO names * @{ */ #define GPIO0 (GPIO_PIN(PORT_GPIO,0)) #define GPIO1 (GPIO_PIN(PORT_GPIO,1)) #define GPIO2 (GPIO_PIN(PORT_GPIO,2)) #define GPIO3 (GPIO_PIN(PORT_GPIO,3)) #define GPIO4 (GPIO_PIN(PORT_GPIO,4)) #define GPIO5 (GPIO_PIN(PORT_GPIO,5)) #define GPIO6 (GPIO_PIN(PORT_GPIO,6)) #define GPIO7 (GPIO_PIN(PORT_GPIO,7)) #define GPIO8 (GPIO_PIN(PORT_GPIO,8)) #define GPIO9 (GPIO_PIN(PORT_GPIO,9)) #define GPIO10 (GPIO_PIN(PORT_GPIO,10)) #define GPIO11 (GPIO_PIN(PORT_GPIO,11)) #define GPIO12 (GPIO_PIN(PORT_GPIO,12)) #define GPIO13 (GPIO_PIN(PORT_GPIO,13)) #define GPIO14 (GPIO_PIN(PORT_GPIO,14)) #define GPIO15 (GPIO_PIN(PORT_GPIO,15)) #define GPIO16 (GPIO_PIN(PORT_GPIO,16)) #define GPIO17 (GPIO_PIN(PORT_GPIO,17)) #define GPIO18 (GPIO_PIN(PORT_GPIO,18)) #define GPIO19 (GPIO_PIN(PORT_GPIO,19)) /* GPIO 20 is not available */ #define GPIO21 (GPIO_PIN(PORT_GPIO,21)) #define GPIO22 (GPIO_PIN(PORT_GPIO,22)) #define GPIO23 (GPIO_PIN(PORT_GPIO,23)) /* GPIO 24 is not available */ #define GPIO25 (GPIO_PIN(PORT_GPIO,25)) #define GPIO26 (GPIO_PIN(PORT_GPIO,26)) #define GPIO27 (GPIO_PIN(PORT_GPIO,27)) /* GPIOs 28 ...32 are not available */ #define GPIO32 (GPIO_PIN(PORT_GPIO,32)) #define GPIO33 (GPIO_PIN(PORT_GPIO,33)) /* GPIOs 34 ... 39 can only be used as inputs and do not have pullups/pulldowns */ #define GPIO34 (GPIO_PIN(PORT_GPIO,34)) #define GPIO35 (GPIO_PIN(PORT_GPIO,35)) #define GPIO36 (GPIO_PIN(PORT_GPIO,36)) #define GPIO37 (GPIO_PIN(PORT_GPIO,37)) #define GPIO38 (GPIO_PIN(PORT_GPIO,38)) #define GPIO39 (GPIO_PIN(PORT_GPIO,39)) /** @} */ /** * @name ADC configuration * * ESP32 integrates two 12-bit ADCs (ADC1 and ADC2) capable of measuring up to * 18 analog signals in total. Most of these ADC channels are either connected * to a number of integrated sensors like a Hall sensors, touch sensors and a * temperature sensor or can be connected with certain GPIOs. Integrated * sensors are disabled in RIOT's implementation and are not accessible. Thus, * up to 18 GPIOs, the RTC GPIOs, can be used as ADC inputs: * * - ADC1 supports 8 channels: GPIO 32-39 * - ADC2 supports 10 channels: GPIO 0, 2, 4, 12-15, 25-27 * * For each ADC line, an attenuation of the input signal can be defined * separately unsing function *adc_set_attenuation*, see file * ```$RIOTBASE/cpu/esp32/include/adc_arch.h```. * 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: * *
* * Attenuation | Voltage Range | Symbol * ----------------|-------------------|---------------------- * 0 dB | 0 ... 1.1V (Vref) | ADC_ATTENUATION_0_DB * 3 dB | 0 ... 1.5V | ADC_ATTENUATION_3_DB * 6 dB | 0 ... 2.2V | ADC_ATTENUATION_6_DB * 11 dB (default) | 0 ... 3.3V | ADC_ATTENUATION_11_DB * *
* * Please note: The reference voltage Vref can vary from device to device in * the range of 1.0V and 1.2V. The Vref of a device can be read with the * function *adc_vref_to_gpio25* at the pin GPIO 25, see file * ```$RIOTBASE/cpu/esp32/include/adc_arch.h```. The results of the ADC * input can then be adjusted accordingly. * * ADC_GPIOS in the board-specific peripheral configuration defines a list of * GPIOs that can be used as ADC channels. The order of the listed GPIOs * determines the mapping between the RIOT's ADC lines and the GPIOs. * * @note ADC_GPIOS must be defined even if there are no GPIOs that could be * used as ADC channels on the board. In this case, an empty list hast to be * defined which just contains the curly braces. * * ADC_NUMOF is determined automatically from the ADC_GPIOS definition. * * @note As long as the GPIOs listed in ADC_GPIOS are not initialized * as ADC channels with the *adc_init* function, they can be used for other * purposes. * * @{ */ #ifndef DOXYGEN /** * @brief Possible ADC resolution settings */ #define HAVE_ADC_RES_T typedef enum { ADC_RES_6BIT = 0xf0, /**< ADC resolution: 6 bit is not supported */ ADC_RES_8BIT = 0xf1, /**< ADC resolution: 8 bit is not supported */ ADC_RES_9BIT = 0, /**< ADC resolution: 9 bit */ ADC_RES_10BIT = 1, /**< ADC resolution: 10 bit */ ADC_RES_11BIT = 2, /**< ADC resolution: 11 bit */ ADC_RES_12BIT = 3, /**< ADC resolution: 12 bit */ ADC_RES_14BIT = 0xf2, /**< ADC resolution: 14 bit is not supported */ ADC_RES_16BIT = 0xf3, /**< ADC resolution: 16 bit is not supported */ } adc_res_t; /** @} */ #endif /* ndef DOXYGEN */ /** * @brief Number of ADC channels that could be used at maximum * * @note GPIO37 and GPIO38 are usually not broken out on ESP32 modules and are * therefore not usable. The maximum number of ADC channels (ADC_NUMOF_MAX) * is therefore set to 16. */ #define ADC_NUMOF_MAX 16 /** @} */ /** * @name DAC configuration * * ESP32 supports 2 DAC lines at GPIO25 and GPIO26. These DACs have a width of * 8 bits and produce voltages in the range from 0 V to 3.3 V (VDD_A). The 16 * bits DAC values given as parameter of function *dac_set* are down-scaled * to 8 bit. * * DAC_GPIOS in the board-specific peripheral configuration defines a list of * GPIOs that can be used as DAC channels. The order of the listed GPIOs * determines the mapping between the RIOT's DAC lines and the GPIOs. * * @note DAC_GPIOS must be defined even if there are no GPIOs that could be * used as DAC channels on the board. In this case, an empty list hast to be * defined which just contains the curly braces. * * DAC_NUMOF is determined automatically from the DAC_GPIOS definition. * * @note As long as the GPIOs listed in DAC_GPIOS are not initialized * as DAC channels with the *dac_init* function, they can be used for other * purposes. * @{ */ /** * @brief Number of DAC channels that could be used at maximum. */ #define DAC_NUMOF_MAX 2 /** @} */ /** * @name I2C configuration * * ESP32 has two built-in I2C interfaces. * * The board-specific configuration of the I2C interface I2C_DEV(n) requires * the definition of * * I2Cn_SPEED, the bus speed, * I2Cn_SCL, the GPIO used as SCL signal, and * I2Cn_SDA, the GPIO used as SDA signal, * * where n can be 0 or 1. If they are not defined, the I2C interface * I2C_DEV(n) is not used. * * @note The configuration of the I2C interfaces I2C_DEV(n) must be in * continuous ascending order of n. * * I2C_NUMOF is determined automatically from board-specific peripheral * definitions of I2Cn_SPEED, I2Cn_SCK, and I2Cn_SDA. * * @{ */ #ifndef DOXYGEN /** * @brief Override I2C clock speed values * * This is required here to have i2c_speed_t defined in this file. * @{ */ #define HAVE_I2C_SPEED_T typedef enum { I2C_SPEED_LOW = 0, /**< 10 kbit/s */ I2C_SPEED_NORMAL, /**< 100 kbit/s */ I2C_SPEED_FAST, /**< 400 kbit/s */ I2C_SPEED_FAST_PLUS, /**< 1 Mbit/s */ I2C_SPEED_HIGH, /**< not supported */ } i2c_speed_t; /** @} */ #endif /* ndef DOXYGEN */ /** * @brief I2C configuration structure type */ typedef struct { i2c_speed_t speed; /**< I2C bus speed */ gpio_t scl; /**< GPIO used as SCL pin */ gpio_t sda; /**< GPIO used as SDA pin */ } i2c_conf_t; /** * @brief Maximum number of I2C interfaces that can be used by board definitions */ #define I2C_NUMOF_MAX (2) #define PERIPH_I2C_NEED_READ_REG /**< i2c_read_reg required */ #define PERIPH_I2C_NEED_READ_REGS /**< i2c_read_regs required */ #define PERIPH_I2C_NEED_WRITE_REG /**< i2c_write_reg required */ #define PERIPH_I2C_NEED_WRITE_REGS /**< i2c_write_regs required */ /** @} */ /** * @name PWM configuration * * The implementation of the PWM peripheral driver uses the LED PWM Controller * (LEDC) module of the ESP32x SoC. This LEDC module has one or two channel * groups with 6 or 8 channels each. The channels of each channel group can * use one of 4 timers as clock source. Thus, it is possible to define at * 4 or 8 virtual PWM devices in RIOT with different frequencies and * resolutions. Regardless of whether the LEDC module of the ESP32x SoC has * one or two channel groups, the PWM driver implementation allows to organize * the available channels into up to 4 virtual PWM devices. * * The assignment of the available channels to the virtual PWM devices is * done in the board-specific peripheral configuration by defining the * macros `PWM0_GPIOS`, `PWM1_GPIOS`, `PWM2_GPIOS` and `PWM3_GPIOS` These * macros specify the GPIOs that are used as channels for the available * virtual PWM devices PWM_DEV(0) ... PWM_DEV(3) in RIOT. The mapping of * these channels to the available channel groups and channel group timers * is done by the driver automatically as follows. * *
* Macro | 1 Channel Group | 2 Channel Groups | Timer * -------------|-----------------------|------------------------|--------------- * `PWM0_GPIOS` | `LEDC_LOW_SPEED_MODE` | `LEDC_LOW_SPEED_MODE` | `LEDC_TIMER_0` * `PWM1_GPIOS` | `LEDC_LOW_SPEED_MODE` | `LEDC_HIGH_SPEED_MODE` | `LEDC_TIMER_1` * `PWM2_GPIOS` | `LEDC_LOW_SPEED_MODE` | `LEDC_LOW_SPEED_MODE` | `LEDC_TIMER_2` * `PWM3_GPIOS` | `LEDC_LOW_SPEED_MODE` | `LEDC_HIGH_SPEED_MODE` | `LEDC_TIMER_3` * *
* For example, if the LEDC module of the ESP32x SoC has two channel groups, * two virtual PWM devices with 2 x 6/8 channels could be used by defining * 'PWM0_GPIOS' and 'PWM1_GPIOS' with 6/8 GPIOs each. * * @note * - The total number of channels defined for a channel group must not exceed * #PWM_CH_NUMOF_MAX. * - The definition of `PWM0_GPIOS`, `PWM1_GPIOS`, `PWM2_GPIOS` and * `PWM3_GPIOS` can be omitted. In this case the existing macros should * be defined in ascending order, as the first defined macro is assigned * to PWM_DEV(0), the second defined macro is assigned to PWM_DEV(1) * and so on. So the minimal configuration would define all channels by * `PWM0_GPIOS` as PWM_DEV(0). * - #PWM_NUMOF is determined automatically. * - The order of the GPIOs in these macros determines the mapping between * RIOT's PWM channels and the GPIOs. * - As long as the GPIOs listed in `PWM0_GPIOS`, `PWM1_GPIOS`, * `PWM2_GPIOS` and `PWM3_GPIOS` are not initialized as PWM channels with * the #pwm_init function, they can be used for other purposes. * * @{ */ /** * @brief PWM configuration structure type * * The implementation of the PWM peripheral driver uses the LED PWM Controller * (LEDC) module of the ESP32x SoC. The LEDC module has up to 2 channel groups * with 6 or 8 channels each, which can use one of 4 timers. * * Based on these maximum 2 channel groups with 6 or 8 channels each and 4 * timers, up to 4 PWM devices can be configured in RIOT. The configuration * structure defines static parameters for each virtual PWM device, i.e. * the channel group used, the timer used, the number of channels used and * the GPIOs assigned to the channels. The number of channels used by a PWM * device corresponds to the number of GPIOs assigned to this PWM device. */ typedef struct { uint8_t module; /**< LEDC module identifier */ ledc_mode_t group; /**< LEDC channel group used (low/high speed) */ ledc_timer_t timer; /**< LEDC timer used by this device */ uint8_t ch_numof; /**< Number of channels used by this device */ const gpio_t *gpios; /**< GPIOs used as channels of this device */ } pwm_config_t; /** * @brief Maximum number of PWM devices */ #define PWM_NUMOF_MAX (4) /** * @brief Maximum number of channels per PWM device. */ #define PWM_CH_NUMOF_MAX (SOC_LEDC_CHANNEL_NUM) /** @} */ /** * @name RNG configuration * @{ */ /** * @brief The address of the register for accessing the hardware RNG. */ #define RNG_DATA_REG_ADDR (WDEV_RND_REG) /** @} */ /** * @name RTT and RTC configuration * @{ */ /** * @brief RTT frequency definition * * The RTT frequency is always 32.768 kHz even if no external crystal is * connected. In this case the RTT value counted with the internal 150 kHz * RC oscillator is converted to a value for an RTT with 32.768 kHz. */ #define RTT_FREQUENCY (32768UL) /** * @brief RTT is a 32-bit counter */ #define RTT_MAX_VALUE (0xFFFFFFFFUL) /** @} */ /** * @name SPI configuration * * ESP32 has four SPI controllers: * * - controller SPI0 is reserved for caching the flash memory (CPSI) * - controller SPI1 is reserved for external memories like flash and PSRAM (FSPI) * - controller SPI2 realizes interface HSPI that can be used for peripherals * - controller SPI3 realizes interface VSPI that can be used for peripherals * * Thus, a maximum of two SPI controllers can be used as peripheral interfaces: * * - VSPI * - HSPI * * SPI interfaces could be used in quad SPI mode, but RIOT's low level * device driver doesn't support it. * * The board-specific configuration of the SPI interface SPI_DEV(n) requires * the definition of * * - SPIn_CTRL, the SPI controller which is used for the interface (VSPI or HSPI), * - SPIn_SCK, the GPIO used as clock signal * - SPIn_MISO, the GPIO used as MISO signal * - SPIn_MOSI, the GPIO used as MOSI signal, and * - SPIn_CS0, the GPIO used as CS signal when the cs parameter in spi_aquire * is GPIO_UNDEF, * * where n can be 0 or 1. If they are not defined, the according SPI interface * SPI_DEV(n) is not used. * * SPI_NUMOF is determined automatically from the board-specific peripheral * definitions of SPIn_*. * * @{ */ #ifndef DOXYGEN /** * @brief Override SPI clock speed values * @{ */ #define HAVE_SPI_CLK_T typedef enum { SPI_CLK_100KHZ = 100000, /**< drive the SPI bus with 100KHz */ SPI_CLK_400KHZ = 400000, /**< drive the SPI bus with 400KHz */ SPI_CLK_1MHZ = 1000000, /**< drive the SPI bus with 1MHz */ SPI_CLK_5MHZ = 5000000, /**< drive the SPI bus with 5MHz */ SPI_CLK_10MHZ = 10000000 /**< drive the SPI bus with 10MHz */ } spi_clk_t; /** @} */ #endif /* !DOXYGEN */ /** * @brief SPI controllers that can be used for peripheral interfaces */ typedef enum { HSPI = HSPI_HOST, /**< HSPI interface controller */ VSPI = VSPI_HOST, /**< VSPI interface controller */ } spi_ctrl_t; /** * @brief SPI configuration structure type */ typedef struct { spi_ctrl_t ctrl; /**< SPI controller used for the interface */ gpio_t sck; /**< GPIO used as SCK pin */ gpio_t mosi; /**< GPIO used as MOSI pin */ gpio_t miso; /**< GPIO used as MISO pin */ gpio_t cs; /**< GPIO used as CS0 pin */ } spi_conf_t; /** * @brief Maximum number of SPI interfaces that can be used by board definitions */ #define SPI_NUMOF_MAX (SOC_SPI_PERIPH_NUM - 1) #define PERIPH_SPI_NEEDS_TRANSFER_BYTE /**< requires function spi_transfer_byte */ #define PERIPH_SPI_NEEDS_TRANSFER_REG /**< requires function spi_transfer_reg */ #define PERIPH_SPI_NEEDS_TRANSFER_REGS /**< requires function spi_transfer_regs */ /** @} */ /** * @name Timer configuration depending on which implementation is used * * Timers are MCU built-in feature and not board-specific. They are therefore * configured here. * @{ */ #ifdef MODULE_ESP_HW_COUNTER /** Hardware ccount/ccompare registers are used for timer implementation */ #define TIMER_NUMOF (2) #define TIMER_CHANNEL_NUMOF (1) #else /** * @brief Hardware timer modules are used for timer implementation (default) * * Since one timer is used for the system time, there is one timer less than * the total number of timers. */ #define TIMER_NUMOF (SOC_TIMER_GROUP_TOTAL_TIMERS - 1) #define TIMER_CHANNEL_NUMOF (1) #endif /** Timer group used for system time */ #define TIMER_SYSTEM_GROUP TIMER_GROUP_0 /** Index of the timer in the timer timer group used for system time */ #define TIMER_SYSTEM_INDEX TIMER_0 /** System time interrupt source */ #define TIMER_SYSTEM_INT_SRC ETS_TG0_T0_LEVEL_INTR_SOURCE /** @} */ /** * @brief Prevent shared timer functions from being used */ #define PERIPH_TIMER_PROVIDES_SET /** * @name UART configuration * * ESP32 supports up to three UART devices. UART_DEV(0) has a fixed pin * configuration and is always available. All ESP32 boards use it as standard * configuration for the console. * * UART_DEV(0).TXD GPIO1 * UART_DEV(0).RXD GPIO3 * * The pin configuration of UART_DEV(1) and UART_DEV(2) are defined in * board specific peripheral configuration by * * - UARTn_TXD, the GPIO used as TxD signal, and * - UARTn_RXD, the GPIO used as RxD signal, * * where n can be 1 or 2. If they are not defined, the according UART interface * UART_DEV(n) is not used. * * UART_NUMOF is determined automatically from the board-specific peripheral * definitions of UARTn_*. * * @{ */ /** * @brief UART configuration structure type */ typedef struct { gpio_t txd; /**< GPIO used as TxD pin */ gpio_t rxd; /**< GPIO used as RxD pin */ } uart_conf_t; /** * @brief Maximum number of UART interfaces */ #define UART_NUMOF_MAX (3) /** @} */ #ifdef MODULE_PERIPH_CAN #include "can_esp.h" #endif #ifdef __cplusplus } #endif #endif /* PERIPH_CPU_H */ /** @} */