2023-07-07 15:34:35 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2023 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_esp32s3_usb_otg ESP32-S3-USB-OTG Board
|
|
|
|
* @ingroup boards_esp32s3
|
|
|
|
* @brief Support for the ESP32-S3-USB-OTG board
|
|
|
|
* @author Gunar Schorcht <gunar@schorcht.net>
|
|
|
|
|
|
|
|
\section esp32s3_usb_otg ESP32-S3-USB-OTG
|
|
|
|
|
|
|
|
## Table of Contents {#esp32s3_usb_otg_toc}
|
|
|
|
|
|
|
|
1. [Overview](#esp32s3_usb_otg_overview)
|
|
|
|
2. [Hardware](#esp32s3_usb_otg_hardware)
|
|
|
|
1. [MCU](#esp32s3_usb_otg_mcu)
|
|
|
|
2. [Board Configuration](#esp32s3_usb_otg_board_configuration)
|
|
|
|
3. [Flashing the Device](#esp32s3_usb_otg_flashing)
|
2023-12-06 08:02:48 +01:00
|
|
|
4. [Using STDIO](#esp32s3_usb_otg_stdio)
|
2023-07-07 15:34:35 +02:00
|
|
|
|
|
|
|
## Overview {#esp32s3_usb_otg_overview}
|
|
|
|
|
|
|
|
The Espressif ESP32-S3-USB-OTG is a development board designed for the
|
|
|
|
development of applications that use the USB interface. For this purpose
|
|
|
|
it is equipped with two USB type A ports:
|
|
|
|
|
|
|
|
- `USB_DEV` male port that is used to connect the board as a USB device to a host.
|
|
|
|
- `USB_HOST` female port that is used to connect other USB devices to the board.
|
|
|
|
|
|
|
|
\image html "https://docs.espressif.com/projects/espressif-esp-dev-kits/en/latest/_images/pic_board_top_lable.png" "Espressif ESP32-S3-USB-OTG" width=600px
|
|
|
|
|
|
|
|
@note RIOT-OS does only support the `USB_DEV` port, that is the board can only
|
|
|
|
be used as USB device.
|
|
|
|
|
|
|
|
The main features of the board are:
|
|
|
|
|
|
|
|
| Feature | Support |
|
|
|
|
|:-------------------------------|:--------------:|
|
|
|
|
| ESP32-S3 SoC | yes (1 core) |
|
|
|
|
| 2.4 GHz WiFi 802.11b/g/n | yes |
|
|
|
|
| Bluetooth5, BLE | yes |
|
|
|
|
| 8 MByte Flash | yes |
|
|
|
|
| USB Type-A Host Interface | no |
|
|
|
|
| USB Type-A Device Interface | yes |
|
|
|
|
| SD Card Slot | yes (SPI mode) |
|
|
|
|
| LCD Color Display 240 x 240 | yes |
|
|
|
|
|
|
|
|
## Hardware {#esp32s3_usb_otg_hardware}
|
|
|
|
|
|
|
|
This section describes
|
|
|
|
|
|
|
|
- the [MCU](#esp32s3_usb_otg_mcu),
|
|
|
|
- the default [board configuration](#esp32s3_usb_otg_board_configuration),
|
|
|
|
|
|
|
|
[Back to table of contents](#esp32s3_usb_otg_toc)
|
|
|
|
|
|
|
|
### MCU {#esp32s3_usb_otg_mcu}
|
|
|
|
|
|
|
|
Most features of the board are provided by the ESP32-S3 SoC. For detailed
|
|
|
|
information about the ESP32-S3 SoC variant (family) and ESP32x SoCs,
|
|
|
|
see section \ref esp32_mcu_esp32 "ESP32 SoC Series".
|
|
|
|
|
|
|
|
[Back to table of contents](#esp32s3_usb_otg_toc)
|
|
|
|
|
|
|
|
### Board Configuration {#esp32s3_usb_otg_board_configuration}
|
|
|
|
|
|
|
|
The Espressif ESP32-S3-USB-OTG is a development board that uses the
|
|
|
|
ESP32-S3-MINI-1 module. Most important features of the board are
|
|
|
|
|
|
|
|
- Micro-SD Card interface
|
2023-09-27 09:11:12 +02:00
|
|
|
- 1.3\" Color LCD display with ST7789 display controller
|
2023-07-07 15:34:35 +02:00
|
|
|
- USB-to-UART bridge
|
|
|
|
- `USB_DEV` Type-A male port
|
|
|
|
- `USB_HOST` Type-A female port
|
|
|
|
|
|
|
|
<center>
|
|
|
|
Function | GPIOs | Remarks | Configuration
|
|
|
|
:-----------------|:-------|:------------|:----------------------------------
|
|
|
|
BTN0 | GPIO0 | OK Button | |
|
|
|
|
BTN1 | GPIO14 | MENU Button | |
|
|
|
|
BTN2 | GPIO11 | DW- Button | |
|
|
|
|
BTN3 | GPIO10 | UP+ active | |
|
|
|
|
LED0 | GPIO15 | Green LED | |
|
|
|
|
LED1 | GPIO16 | Yellow LED | |
|
|
|
|
LCD_DC | GPIO4 | | |
|
|
|
|
LCD_EN | GPIO5 | | |
|
|
|
|
LCD_RST | GPIO8 | | |
|
|
|
|
LCD_BL | GPIO9 | LCD Backlight | |
|
|
|
|
ADC_LINE(0) | GPIO1 | USB_HOST Voltage | \ref esp32_adc_channels "ADC Channels"
|
|
|
|
ADC_LINE(1) | GPIO2 | Battery Voltage | \ref esp32_adc_channels "ADC Channels"
|
|
|
|
PWM_DEV(0):0 | GPIO15 | LED0 | \ref esp32_pwm_channels "PWM Channels"
|
|
|
|
PWM_DEV(0):1 | GPIO16 | LED1 | \ref esp32_pwm_channels "PWM Channels"
|
|
|
|
SPI_DEV(0):SCK | GPIO6 | LCD_SCLK | \ref esp32_spi_interfaces "SPI Interfaces" |
|
|
|
|
SPI_DEV(0):MOSI | GPIO7 | LCD_SDA | \ref esp32_spi_interfaces "SPI Interfaces" |
|
|
|
|
SPI_DEV(0):MISO | GPIO3 | no used | \ref esp32_spi_interfaces "SPI Interfaces" |
|
|
|
|
SPI_DEV(0):CS0 | GPIO5 | LCD_EN | \ref esp32_spi_interfaces "SPI Interfaces" |
|
|
|
|
SPI_DEV(1):SCK | GPIO36 | SD_CLK | \ref esp32_spi_interfaces "SPI Interfaces" |
|
|
|
|
SPI_DEV(1):MOSI | GPIO35 | SD_CMD | \ref esp32_spi_interfaces "SPI Interfaces" |
|
|
|
|
SPI_DEV(1):MISO | GPIO37 | SD_DATA0 | \ref esp32_spi_interfaces "SPI Interfaces" |
|
|
|
|
SPI_DEV(1):CS0 | GPIO34 | SD_DATA3 | \ref esp32_spi_interfaces "SPI Interfaces" |
|
|
|
|
UART_DEV(0):TxD | GPIO43 | USB-to-UART bridge | \ref esp32_uart_interfaces "UART interfaces"
|
|
|
|
UART_DEV(0):RxD | GPIO44 | USB-to-UART bridge | \ref esp32_uart_interfaces "UART interfaces"
|
|
|
|
</center>
|
|
|
|
\n
|
|
|
|
|
|
|
|
For detailed information about the peripheral configurations of ESP32-S3
|
|
|
|
boards, see section \ref esp32_peripherals "Common Peripherals".
|
|
|
|
|
|
|
|
The corresponding board schematic can be found
|
|
|
|
[here](https://docs.espressif.com/projects/espressif-esp-dev-kits/en/latest/_static/esp32-s3-usb-otg/schematics/SCH_ESP32-S3_USB_OTG.pdf)
|
|
|
|
|
|
|
|
[Back to table of contents](#esp32s3_usb_otg_toc)
|
|
|
|
|
|
|
|
## Flashing the Device {#esp32s3_usb_otg_flashing}
|
|
|
|
|
|
|
|
There are two options to flash the board:
|
|
|
|
|
|
|
|
1. USB Serial/JTAG interface using the `USB_DEV` port (default)
|
|
|
|
2. UART-to-UART bridge
|
|
|
|
|
|
|
|
### Flashing the device using the USB Serial/JTAG interface (`USB_DEV` port)
|
|
|
|
|
|
|
|
To flash the board via the USB Serial/JTAG interface just connect the board
|
|
|
|
with the `USB_DEV` port to your host computer and use the following command:
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
BOARD=esp32s3_usb_otg make flash ...
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
Usually the make system resets the board before flashing to enable the
|
|
|
|
USB Serial/JTAG controller and to reboot the ESP32-S3 in download mode.
|
|
|
|
|
|
|
|
In some very special cases this reset does not work and the programmer cannot
|
|
|
|
connect to the card, so the flashing is aborted with a timeout:
|
|
|
|
```
|
|
|
|
Serial port /dev/ttyACM0
|
|
|
|
Connecting...
|
|
|
|
...
|
|
|
|
serial.serialutil.SerialTimeoutException: Write timeout
|
|
|
|
```
|
|
|
|
This can happen either if RIOT is not yet installed or if the USB port was
|
|
|
|
previously used with the USB OTG controller, for example with USBUS or tinyUSB.
|
|
|
|
In this case, restart the board manually into download mode by pressing and
|
|
|
|
releasing the RESET button while holding down the BOOT button.
|
|
|
|
In download mode, the USB Serial/JTAG interface is always available.
|
|
|
|
|
|
|
|
@note If the USB port was previously used with the USB OTG controller, an
|
|
|
|
automatic restart of the ESP32-S3 with the flashed application is not
|
|
|
|
possible. In this case the board must be reset manually using the RESET
|
|
|
|
button. In all other cases the ESP32-S3 automatically restarts with
|
|
|
|
the flashed application.
|
|
|
|
|
|
|
|
### Flashing the device using USB-to-UART bridge
|
|
|
|
|
|
|
|
Flashing RIOT using the USB-to-UART bridge 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:
|
|
|
|
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
BOARD=esp32s3-usb-otg make flash ... PORT=/dev/ttyUSB0
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
For detailed information about ESP32-S3 as well as configuring and compiling
|
|
|
|
RIOT for ESP32-S3 boards, see \ref esp32_riot.
|
|
|
|
|
|
|
|
[Back to table of contents](#esp32s3_usb_otg_toc)
|
|
|
|
|
|
|
|
## Using STDIO {#esp32s3_usb_otg_stdio}
|
|
|
|
|
|
|
|
By default, the `USB_DEV` port and the USB Serial/JTAG interface are used for
|
|
|
|
the STDIO (module `stdio_usb_serial_jtag`). If the USB port is used by the
|
|
|
|
USBUS stack or the tinyUSB stack, implicitly the module `stdio_cdc_acm` or
|
|
|
|
`stdio_tinyusb_cdc_acm` is used for the STDIO via the USB CDC ACM interface.
|
|
|
|
|
|
|
|
Alternatively, the USB-to-UART bridge and `UART_DEV(0)` could be used for the
|
|
|
|
STDIO. Simply add `stdio_uart` to the list of used modules for this purpose:
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
BOARD=esp32s3-usb-otg USEMODULE=stdio_uart make flash ...
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
*/
|