2018-10-08 12:20:49 +02:00
|
|
|
/*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @defgroup boards_esp32_wroom-32 Generic ESP32-WROOM-32 boards
|
|
|
|
* @ingroup boards_esp32
|
|
|
|
* @brief Support for generic ESP32-WROOM-32 boards
|
|
|
|
* @author Gunar Schorcht <gunar@schorcht.net>
|
|
|
|
|
2021-10-13 17:09:06 +02:00
|
|
|
\section esp32_wroom_32 ESP32-WROOM-32 based boards
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:09:06 +02:00
|
|
|
## Table of Contents {#esp32_wroom_32_toc}
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:09:06 +02:00
|
|
|
1. [Overview](#esp32_wroom_32_overview)
|
|
|
|
2. [Hardware](#esp32_wroom_32_hardware)
|
|
|
|
1. [MCU](#esp32_wroom_32_mcu)
|
|
|
|
2. [Board Configuration](#esp32_wroom_32_board_configuration)
|
|
|
|
3. [Board Pinout](#esp32_wroom_32_pinout)
|
|
|
|
4. [Optional Hardware Configurations](#esp32_wroom_32_optional_hardware)
|
|
|
|
3. [Flashing the Device](#esp32_wroom_32_flashing)
|
|
|
|
|
|
|
|
## Overview {#esp32_wroom_32_overview}
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:11:49 +02:00
|
|
|
This board definition covers not just a single board, but rather a large set
|
|
|
|
of generic boards that use an ESP32-WROOM-32 module and simply break out all
|
|
|
|
GPIOs to external pads without having any special hardware or interfaces
|
|
|
|
on-board. Examples are Espressif's ESP32-DevKitC or NodeMCU-ESP32S and a
|
|
|
|
large number of clones.
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:09:06 +02:00
|
|
|
\image html "https://dl.espressif.com/dl/schematics/pictures/esp32-devkitc-v4-front.jpg" "Espressif ESP32-DevKitC V4" width=400px
|
|
|
|
|
|
|
|
[Back to table of contents](#esp32_wroom_32_toc)
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:09:06 +02:00
|
|
|
## Hardware {#esp32_wroom_32_hardware}
|
2018-10-08 12:20:49 +02:00
|
|
|
|
|
|
|
This section describes
|
|
|
|
|
2021-10-13 17:09:06 +02:00
|
|
|
- the [MCU](#esp32_wroom_32_mcu),
|
|
|
|
- the default [board configuration](#esp32_wroom_32_board_configuration),
|
|
|
|
- [optional hardware configurations](#esp32_wroom_32_optional_hardware),
|
|
|
|
- the [board pinout](#esp32_wroom_32_pinout).
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:09:06 +02:00
|
|
|
[Back to table of contents](#esp32_wroom_32_toc)
|
|
|
|
|
|
|
|
### MCU {#esp32_wroom_32_mcu}
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2020-02-20 08:47:18 +01:00
|
|
|
Most features of the board are provided by the ESP32 SoC. For detailed
|
2021-10-05 16:06:58 +02:00
|
|
|
information about the ESP32, see section \ref esp32_mcu_esp32 "MCU ESP32".
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:09:06 +02:00
|
|
|
[Back to table of contents](#esp32_wroom_32_toc)
|
|
|
|
|
|
|
|
### Board Configuration {#esp32_wroom_32_board_configuration}
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:11:49 +02:00
|
|
|
Generic ESP32-WROOM-32 boards do not have special hardware on board and all
|
|
|
|
GPIOs are simply broken out for flexibility. Therefore, the board
|
|
|
|
configuration is the most flexible one with provides:
|
2018-10-08 12:20:49 +02:00
|
|
|
|
|
|
|
18 x ADC channels at maximum
|
|
|
|
2 x DAC channels at maximum
|
|
|
|
2 x SPI at maximum
|
|
|
|
1 x I2C at maximum
|
|
|
|
2 x UART
|
|
|
|
|
2021-10-13 17:11:49 +02:00
|
|
|
Since all GPIOs have broken out, GPIOs can be used for different purposes
|
|
|
|
in different applications. For flexibility, GPIOs can be listed in various
|
|
|
|
peripheral configurations. For example, GPIO13 is used in the ADC channel
|
|
|
|
definition and the definition of the MOSI signal of SPI_DEV(0).
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:11:49 +02:00
|
|
|
This is possible because GPIOs are only used for a specific peripheral
|
|
|
|
interface when
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:11:49 +02:00
|
|
|
- the corresponding peripheral module is used, e.g. `periph_i2c`, or
|
|
|
|
- a corresponding init function is called z. `adc_init`, `dac_init` and
|
|
|
|
`pwm_init` or
|
|
|
|
- The corresponding peripheral interface is used for the first time,
|
|
|
|
e.g. `spi_aqcuire.
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:11:49 +02:00
|
|
|
That is, the purpose for which a GPIO is used depends on which module
|
|
|
|
or function is used first.
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:11:49 +02:00
|
|
|
For example, if module periph_i2c is not used, the GPIOs listed in I2C
|
|
|
|
configuration can be used for the other purposes.
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:11:49 +02:00
|
|
|
The following table shows the default board configuration, which is sorted
|
|
|
|
according to the defined functionality of GPIOs. This configuration can be
|
|
|
|
overridden by \ref esp32_application_specific_configurations
|
|
|
|
"application-specific configurations".
|
2018-10-08 12:20:49 +02:00
|
|
|
|
|
|
|
<center>
|
|
|
|
Function | GPIOs | Remarks |Configuration
|
|
|
|
:---------------|:-------|:--------|:----------------------------------
|
|
|
|
BUTTON0 | GPIO0 | | |
|
2021-10-13 17:09:06 +02:00
|
|
|
ADC | GPIO0, GPIO2, GPIO4, GPIO12, GPIO13,\n GPIO14, GPIO15, GPIO25, GPIO26, GPIO27,\n GPIO32, GPIO33, GPIO34, GPIO35, GPIO36,\n GPIO39 | | see \ref esp32_adc_channels "ADC Channels"
|
2018-10-08 12:20:49 +02:00
|
|
|
DAC | GPIO25, GPIO26 | | \ref esp32_dac_channels "refer"
|
|
|
|
PWM_DEV(0) | GPIO0, GPIO2, GPIO4, GPIO16, GPIO17 | - | \ref esp32_pwm_channels "DAC Channels"
|
|
|
|
PWM_DEV(1) | GPIO27, GPIO32, GPIO33 | - | \ref esp32_pwm_channels "PWM Channels"
|
|
|
|
I2C_DEV(0):SDA | GPIO21 | | \ref esp32_i2c_interfaces "I2C Interfaces"
|
|
|
|
I2C_DEV(0):SCL | GPIO22 | | \ref esp32_i2c_interfaces "I2C Interfaces"
|
|
|
|
SPI_DEV(0):CLK | GPIO18 | VSPI is used | \ref esp32_spi_interfaces "SPI Interfaces"
|
|
|
|
SPI_DEV(0):MISO | GPIO19 | VSPI is used | \ref esp32_spi_interfaces "SPI Interfaces"
|
|
|
|
SPI_DEV(0):MOSI | GPIO23 | VSPI is used | \ref esp32_spi_interfaces "SPI Interfaces"
|
|
|
|
SPI_DEV(0):CS0 | GPIO5 | VSPI is used | \ref esp32_spi_interfaces "SPI Interfaces"
|
|
|
|
SPI_DEV(1):CLK | GPIO14 | HSPI is used | \ref esp32_spi_interfaces "SPI Interfaces"
|
|
|
|
SPI_DEV(1):MISO | GPIO12 | HSPI is used | \ref esp32_spi_interfaces "SPI Interfaces"
|
|
|
|
SPI_DEV(1):MOSI | GPIO13 | HSPI is used | \ref esp32_spi_interfaces "SPI Interfaces"
|
|
|
|
SPI_DEV(1):CS0 | GPIO15 | HSPI is used | \ref esp32_spi_interfaces "SPI Interfaces"
|
|
|
|
UART_DEV(0):TxD | GPIO1 | Console (configuration is fixed) | \ref esp32_uart_interfaces "UART interfaces"
|
|
|
|
UART_DEV(0):RxD | GPIO3 | Console (configuration is fixed) | \ref esp32_uart_interfaces "UART interfaces"
|
|
|
|
UART_DEV(1):TxD | GPIO10 | not available in **qout** and **qio** flash mode | \ref esp32_uart_interfaces "UART interfaces"
|
|
|
|
UART_DEV(1):RxD | GPIO9 | not available in **qout** and **qio** flash mode | \ref esp32_uart_interfaces "UART interfaces"
|
|
|
|
</center>
|
2021-10-13 17:09:06 +02:00
|
|
|
\n
|
2018-10-08 12:20:49 +02:00
|
|
|
@note
|
2021-10-13 17:11:49 +02:00
|
|
|
- The configuration of ADC channels contains all ESP32 GPIOs that can be
|
|
|
|
used as ADC channels.
|
|
|
|
- The configuration of DAC channels contains all ESP32 GPIOs that can be used
|
|
|
|
as DAC channels.
|
|
|
|
- GPIO9 and GIOP10 can only be used in **dout** and **dio**
|
|
|
|
\ref esp32_flash_modes "flash modes".
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:11:49 +02:00
|
|
|
For detailed information about the configuration of ESP32 boards, see
|
|
|
|
section \ref esp32_peripherals "Common Peripherals".
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:09:06 +02:00
|
|
|
[Back to table of contents](#esp32_wroom_32_toc)
|
|
|
|
|
|
|
|
### Optional Hardware Configurations {#esp32_wroom_32_optional_hardware}
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:11:49 +02:00
|
|
|
MRF24J40-based IEEE 802.15.4 radio modules and ENC28J60-based Ethernet
|
|
|
|
network interface modules have been tested with the board. You could use
|
|
|
|
the following code in your \ref esp32_application_specific_configurations
|
|
|
|
"application-specific configuration" to use such modules:
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:09:06 +02:00
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~{.c}
|
2018-10-08 12:20:49 +02:00
|
|
|
#ifdef BOARD_ESP32_WROOM-32
|
|
|
|
|
|
|
|
#if MODULE_MRF24J40
|
2020-03-09 16:51:35 +01:00
|
|
|
#define MRF24J40_PARAM_CS GPIO16 /* MRF24J40 CS signal */
|
|
|
|
#define MRF24J40_PARAM_RESET GPIO17 /* MRF24J40 RESET signal */
|
|
|
|
#define MRF24J40_PARAM_INT GPIO34 /* MRF24J40 INT signal */
|
|
|
|
#define MRF24J40_PARAM_SPI_CLK SPI_CLK_1MHZ /* SPI clock frequency */
|
2018-10-08 12:20:49 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#if MODULE_ENC28J80
|
|
|
|
#define ENC28J80_PARAM_CS GPIO32 /* ENC28J80 CS signal */
|
|
|
|
#define ENC28J80_PARAM_RESET GPIO33 /* ENC28J80 RESET signal */
|
|
|
|
#define ENC28J80_PARAM_INT GPIO35 /* ENC28J80 INT signal */
|
2019-04-10 11:23:23 +02:00
|
|
|
#endif
|
2018-10-08 12:20:49 +02:00
|
|
|
|
|
|
|
#endif
|
2021-10-13 17:09:06 +02:00
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2018-10-08 12:20:49 +02:00
|
|
|
For other parameters, the default values defined by the drivers can be used.
|
|
|
|
|
2021-10-13 17:11:49 +02:00
|
|
|
@note The **RESET** signal of MRF24J40 and ENC28J60 based modules can also
|
|
|
|
be connected to the **RST** pin of the board (see \ref esp32_wroom_32_pinout
|
|
|
|
"pinout") to keep the configured GPIO free for other purposes.
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:09:06 +02:00
|
|
|
[Back to table of contents](#esp32_wroom_32_toc)
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:09:06 +02:00
|
|
|
### Board Pinout {#esp32_wroom_32_pinout}
|
|
|
|
|
2021-10-13 17:11:49 +02:00
|
|
|
The following figure shows the pinout of the defined default configuration
|
|
|
|
for the EPS32-DevKitC board as an example of generic ESP32-WROOM-32 boards.
|
|
|
|
The light green GPIOs are not used by configured on-board hardware components
|
|
|
|
and can be used for any purpose. However, if optional off-board hardware
|
|
|
|
modules are used, these GPIOs may also be occupied, see
|
|
|
|
section \ref esp32_wroom_32_board_configuration for more information.
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2023-09-27 09:10:15 +02:00
|
|
|
The corresponding board schematics can be found
|
|
|
|
[here](https://dl.espressif.com/dl/schematics/esp32_devkitc_v4-sch-20180607a.pdf)
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:09:06 +02:00
|
|
|
@image html "https://gitlab.com/gschorcht/RIOT.wiki-Images/raw/master/esp32/ESP32-WROOM-32_pinouts.png" "EPS32-DevKitC V4 Pinout"
|
|
|
|
|
|
|
|
[Back to table of contents](#esp32_wroom_32_toc)
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:09:06 +02:00
|
|
|
## Flashing the Device {#esp32_wroom_32_flashing}
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:11:49 +02:00
|
|
|
Flashing RIOT is quite easy. The board has a Micro-USB connector with
|
|
|
|
reset/boot/flash logic. Just connect the board to your host computer
|
|
|
|
and type using the programming port:
|
2021-10-13 17:09:06 +02:00
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2018-10-08 12:20:49 +02:00
|
|
|
make flash BOARD=esp32-wroom-32 ...
|
2021-10-13 17:09:06 +02:00
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2021-10-13 17:11:49 +02:00
|
|
|
For detailed information about ESP32 as well as configuring and compiling
|
|
|
|
RIOT for ESP32 boards, see \ref esp32_riot.
|
2018-10-08 12:20:49 +02:00
|
|
|
|
2021-10-13 17:09:06 +02:00
|
|
|
[Back to table of contents](#esp32_wroom_32_toc)
|
2018-10-08 12:20:49 +02:00
|
|
|
*/
|