23 #if defined(CPU_FAM_ESP32)
25 #elif defined(CPU_FAM_ESP32C3)
27 #elif defined(CPU_FAM_ESP32H2)
29 #elif defined(CPU_FAM_ESP32S2)
31 #elif defined(CPU_FAM_ESP32S3)
34 # error "ESP32x SoC family not supported"
38 #include "periph_cpu.h"
74 #define ADC_NUMOF ARRAY_SIZE(adc_channels)
106 #define DAC_NUMOF ARRAY_SIZE(dac_channels)
114 #if defined(I2C0_SCL) && !defined(I2C0_SCL_PULLUP)
116 #define I2C0_SCL_PULLUP true
119 #if defined(I2C0_SDA) && !defined(I2C0_SDA_PULLUP)
121 #define I2C0_SDA_PULLUP true
124 #if (SOC_I2C_NUM > 1) && defined(I2C1_SCL) && !defined(I2C1_SCL_PULLUP)
126 #define I2C1_SCL_PULLUP true
129 #if (SOC_I2C_NUM > 1) && defined(I2C1_SDA) && !defined(I2C1_SDA_PULLUP)
131 #define I2C1_SDA_PULLUP true
138 #if defined(I2C0_SCL) && defined(I2C0_SDA) && defined(I2C0_SPEED)
140 .
module = PERIPH_I2C0_MODULE,
144 .scl_pullup = I2C0_SCL_PULLUP,
145 .sda_pullup = I2C0_SCL_PULLUP,
148 #if (SOC_I2C_NUM > 1) && defined(I2C1_SCL) && defined(I2C1_SDA) && defined(I2C1_SPEED)
150 .module = PERIPH_I2C1_MODULE,
154 .scl_pullup = I2C1_SCL_PULLUP,
155 .sda_pullup = I2C1_SCL_PULLUP,
168 #define I2C_NUMOF ARRAY_SIZE(i2c_config)
181 static const gpio_t pwm0_gpios[] = PWM0_GPIOS;
188 static const gpio_t pwm1_gpios[] =
PWM1_GPIOS;
195 static const gpio_t pwm2_gpios[] = PWM2_GPIOS;
202 static const gpio_t pwm3_gpios[] = PWM3_GPIOS;
212 .
module = PERIPH_LEDC_MODULE,
213 .group = LEDC_LOW_SPEED_MODE,
214 .timer = LEDC_TIMER_0,
221 .module = PERIPH_LEDC_MODULE,
222 #ifdef SOC_LEDC_SUPPORT_HS_MODE
223 .group = LEDC_HIGH_SPEED_MODE,
225 .group = LEDC_LOW_SPEED_MODE,
227 .timer = LEDC_TIMER_1,
234 .module = PERIPH_LEDC_MODULE,
235 .group = LEDC_LOW_SPEED_MODE,
236 .timer = LEDC_TIMER_2,
243 .module = PERIPH_LEDC_MODULE,
244 #ifdef SOC_LEDC_SUPPORT_HS_MODE
245 .group = LEDC_HIGH_SPEED_MODE,
247 .group = LEDC_LOW_SPEED_MODE,
249 .timer = LEDC_TIMER_3,
263 #define PWM_NUMOF ARRAY_SIZE(pwm_config)
283 #ifndef HAVE_RMT_CHANNEL_CONFIG
285 #ifdef WS281X_PARAM_PIN
297 #define RMT_CH_NUMOF ARRAY_SIZE(rmt_channel_config)
310 #if defined(SPI0_CTRL)
319 #if defined(SPI1_CTRL) && (SOC_SPI_PERIPH_NUM > 2)
338 #define SPI_NUMOF ARRAY_SIZE(spi_config)
340 #if IS_USED(MODULE_PERIPH_SPI)
358 #if (SOC_UART_NUM > 1) && defined(UART1_TXD) && defined(UART1_RXD)
364 #if (SOC_UART_NUM > 2) && defined(UART2_TXD) && defined(UART2_RXD)
380 #define UART_NUMOF ARRAY_SIZE(uart_config)
383 #ifdef SOC_USB_OTG_SUPPORTED
389 #include "usbdev_esp32.h"
396 .
periph = USB_OTG_FS_PERIPH_BASE,
405 #define USBDEV_NUMOF ARRAY_SIZE(dwc2_usb_otg_fshs_config)
#define WS281X_PARAM_PIN
GPIO pin connected to the data pin of the first LED.
#define static_assert(cond,...)
static_assert for c-version < c11
#define I2C0_SPEED
I2C bus speed of I2C_DEV(0)
#define I2C0_SCL
SCL signal of I2C_DEV(0)
#define I2C0_SDA
SDA signal of I2C_DEV(0)
#define PWM1_GPIOS
PWM_DEV(1) is not used.
#define SPI1_MOSI
HSPI MOSI.
#define SPI1_SCK
HSPI SCK.
#define SPI1_MISO
HSPI MISO.
#define SPI1_CS0
HSPI CS0.
#define SPI1_CTRL
HSPI is used as SPI_DEV(1)
#define ARRAY_SIZE(a)
Calculate the number of elements in a static array.
static const uart_conf_t uart_config[]
Static array with configuration for declared UART devices.
#define DAC_GPIOS
Declaration of GPIOs that can be used as DAC channels.
static const pwm_config_t pwm_config[]
GPIOs used as channels for the according PWM device.
static const gpio_t dac_channels[]
Static array with declared DAC channels.
static const spi_conf_t spi_config[]
Static array with configuration for declared SPI devices.
static const rmt_channel_config_t rmt_channel_config[]
RMT channel configuration.
static const gpio_t adc_channels[]
Static array with declared ADC channels.
static const i2c_conf_t i2c_config[]
Static array with configuration for declared I2C devices.
#define SPI_NUMOF
Number of SPI interfaces.
#define ADC_GPIOS
Declaration of GPIOs that can be used as ADC channels.
#define SPI0_MOSI
HSPI / SPI_DEV(0) MOSI pin.
#define SPI0_CTRL
HSPI / SPI_DEV(0) controller.
#define SPI0_CS0
HSPI / SPI_DEV(0) CS default pin, only used when cs parameter in spi_acquire is GPIO_UNDEF.
#define SPI0_SCK
HSPI / SPI_DEV(0) SCK pin.
#define SPI0_MISO
HSPI / SPI_DEV(0) MISO pin.
static const dwc2_usb_otg_fshs_config_t dwc2_usb_otg_fshs_config[]
Common USB OTG FS configuration.
Common macros and compiler attributes/pragmas configuration.
Common declarations of ESP32 periphery for all ESP32 boards.
Common peripheral configurations for ESP32-C3 boards.
Common peripheral configurations for ESP32-H2 boards.
Common peripheral configurations for ESP32-S2 boards.
Common peripheral configurations for ESP32-S3 boards.
uintptr_t periph
USB peripheral base address.
I2C configuration structure.
uint8_t module
I2C module identifier.
PWM configuration structure type.
uint8_t module
LEDC module identifier.
RMT channel configuration.
SPI device configuration.
spi_ctrl_t ctrl
SPI controller used for the interface.
UART device configuration.
gpio_t txd
GPIO used as TxD pin.
@ DWC2_USB_OTG_PHY_BUILTIN
on-chip FS PHY
@ DWC2_USB_OTG_FS
Full speed peripheral.