/* * Copyright (C) 2019 Yegor Yefremov * * 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_ttgo-t-beam TTGO T-Beam * @ingroup boards_esp32 * @brief Support for TTGO T-Beam boards * @author Yegor Yefremov ## Table of Contents 1. [Overview](#overview) 2. [Hardware](#hardware) 1. [MCU](#mcu) 2. [Board Configuration](#board_configuration) 3. [Board Pinout](#pinout) 4. [Optional Hardware Configurations](#optional_hardware) 3. [Flashing the Device](#flashing) ## Overview    [[TOC](#toc)] TTGO T-Beam is an ESP32 development board with 4 MB Flash that uses the EPS32 chip directly. It integrates: - a SemTech SX1276 or SX1278 for LoRaWAN communication - a U-Blox Neo-6M GPS receiver There are at least three board types: rev0, rev1, and V1.0. Versions rev0 and rev1 are very similar, the only difference is that rev1 has an additional LED connected to GPIO14. The pinout of V1.0 has more changes thus it is necessary to add the following line to the makefile of the application to use the according configuration for TTGO T-Beam V1.0: ``` USEMODULE += esp32_ttgo_t_beam_v1_0 ``` ## Hardware    [[TOC](#toc)] This section describes - the [MCU](#mcu), - the default [board configuration](#board_configuration), - [optional hardware configurations](#optional_hardware), - the [board pinout](#pinout). ### MCU    [[TOC](#toc)] Most features of the board are provided by the ESP32 SoC. The following table summarizes these features and gives an overview of which of these features are supported by RIOT. For detailed information about the ESP32, see section \ref esp32_mcu "MCU ESP32".
MCU | ESP32 | Supported by RIOT ------------|-----------|------------------ Vendor | Espressif | | Cores | 1 or 2 x Tensilica Xtensa LX6 | 1 core FPU | yes (ULP - Ultra low power co-processor) | no RAM | 520 kByte SRAM
16 kByte RTC SRAM | yes ROM | 448 kByte | yes Flash | 512 kByte ... 16 MByte | yes Frequency | 240 MHz, 160 MHz, 80 MHz | yes Power Consumption | 68 mA @ 240 MHz
44 mA @ 160 MHz
31 mA @ 80 MHz
5 uA in deep sleep mode | yes
yes
yes
no Timers | 4 x 64 bit | yes ADCs | 2 x SAR-ADC with up to 18 x 12 bit channels total | yes DACs | 2 x DAC with 8 bit | yes GPIOs | 34 (6 of them are only inputs) | yes I2Cs | 2 | yes SPIs | 4 | yes UARTs | 3 | yes WiFi | IEEE 802.11 b/g/n built in | yes Bluetooth | v4.2 BR/EDR and BLE | no Ethernet | MAC interface with dedicated DMA and IEEE 1588 support | yes CAN | version 2.0 | yes IR | up to 8 channels TX/RX | no Motor PWM | 2 devices x 6 channels | yes LED PWM | 16 channels | no Crypto | Hardware acceleration of AES, SHA-2, RSA, ECC, RNG | no Vcc | 2.5 - 3.6 V | | Documents | [Datasheet](https://www.espressif.com/sites/default/files/documentation/esp32_datasheet_en.pdf)
[Technical Reference](https://www.espressif.com/sites/default/files/documentation/esp32_technical_reference_manual_en.pdf) | |
### Board Configuration    [[TOC](#toc)] TTGO T-Beam has the following on-board components: - SemTech SX1276 or SX1278 for LoRaWAN communication - U-Blox Neo-6M GPS receiver There are two hardware versions of the board: - SemTech SX1276 for LoRaWAN communication in the 433 MHz band - SemTech SX1278 for LoRaWAN communication in the 868/915 MHz band Since many GPIOs are broken out, they can be used for different purposes in different applications. For flexibility, some GPIOs might be listed in various peripheral configurations. For example, GPIO0 is used in the ADC channel definition \ref ADC_GPIOS and the PWM channel definition \ref PWM0_GPIOS. This is possible because GPIOs are only used for a specific peripheral interface when - the corresponding peripheral module is used, e.g., module `periph_i2c`, or - a corresponding init function is called e.g., \ref adc_init, \ref dac_init and \ref pwm_init, or - the corresponding peripheral interface is used for the first time, e.g., \ref spi_acquire. That is, the purpose for which a GPIO is actually used depends on which module or function is used first. @note GPIOs 5, 12, 15, 16, 17, 18, 19, 26, and 27 are used for board control functions and should not be used for other purposes unless you exactly know what you are doing. 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_app_spec_conf "application-specific configurations". TTGO- T-Beam rev1
\anchor esp32_ttgo_t_beam_rev1_table_board_configuration Function | GPIOs | Remarks |Configuration :---------------|:-------|:--------|:---------------------------------- BUTTON0 | GPIO39 | low active | | LED0 | GPIO14 | high active | | ADC | GPIO0, GPIO2, GPIO4, GPIO13,
GPIO25, GPIO32, GPIO33, GPIO34,
GPIO35 | | \ref esp32_adc_channels "ADC Channels" DAC | GPIO25 | | \ref esp32_dac_channels "DAC Channels" PWM_DEV(0) | GPIO0, GPIO2, GPIO25 | | \ref esp32_pwm_channels "PWM Channels" I2C_DEV(0):SDA | GPIO21 | | \ref esp32_i2c_interfaces "I2C Interfaces" I2C_DEV(0):SCL | GPIO22 | I2C_SPEED_FAST is used | \ref esp32_i2c_interfaces "I2C Interfaces" SPI_DEV(0):CLK | GPIO5 | 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 | GPIO27 | VSPI is used | \ref esp32_spi_interfaces "SPI Interfaces" SPI_DEV(0):CS0 | GPIO18 | VSPI 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 | GPIO15 | GPS (configuration is fixed) | \ref esp32_uart_interfaces "UART interfaces" UART_DEV(1):RxD | GPIO12 | GPS (configuration is fixed) | \ref esp32_uart_interfaces "UART interfaces"
TTGO- T-Beam V1.0
\anchor esp32_ttgo_t_beam_v1_0_table_board_configuration Function | GPIOs | Remarks |Configuration :---------------|:-------|:--------|:---------------------------------- BUTTON0 | GPIO38 | low active | | ADC | GPIO0, GPIO2, GPIO4, GPIO13,
GPIO25, GPIO32, GPIO33, GPIO35 | | \ref esp32_adc_channels "ADC Channels" DAC | GPIO25 | | \ref esp32_dac_channels "DAC Channels" PWM_DEV(0) | GPIO0, GPIO2, GPIO25 | | \ref esp32_pwm_channels "PWM Channels" I2C_DEV(0):SDA | GPIO21 | | \ref esp32_i2c_interfaces "I2C Interfaces" I2C_DEV(0):SCL | GPIO22 | I2C_SPEED_FAST is used | \ref esp32_i2c_interfaces "I2C Interfaces" SPI_DEV(0):CLK | GPIO5 | 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 | GPIO27 | VSPI is used | \ref esp32_spi_interfaces "SPI Interfaces" SPI_DEV(0):CS0 | GPIO18 | VSPI 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 | GPIO34 | GPS (configuration is fixed) | \ref esp32_uart_interfaces "UART interfaces" UART_DEV(1):RxD | GPIO12 | GPS (configuration is fixed) | \ref esp32_uart_interfaces "UART interfaces"

@note - The configuration of ADC channels contains all ESP32 GPIOs that can be used as ADC channels. For detailed information about the configuration of ESP32 boards, see section \ref esp32_comm_periph "Common Peripherals". ### Board Pinout    [[TOC](#toc)] The following figures show the pinout of the defined default configurations for TTGO T-Beam boards. \anchor esp32_ttgo_t_beam_rev1_pinout @image html "https://ae01.alicdn.com/kf/HTB1OhPmXtzvK1RkSnfoq6zMwVXah.jpg" "TTGO T-Beam rev1 Pintout Diagram" \anchor esp32_ttgo_t_beam_v1_0_pinout @image html "https://ae01.alicdn.com/kf/Hee7e9a85bb294351952a073325e6b2f96.jpg" "TTGO T-Beam V1.0 Pintout Diagram" The corresponding board schematics can be found on TinyMicros.com for [TTGO T-Beam rev0](http://tinymicros.com/mediawiki/images/b/b9/TTGO_T-Beam_Schematic.pdf) and GitHub for [TTGO T-Beam V1.0](https://github.com/Xinyuan-LilyGO/TTGO-T-Beam/raw/master/schematic/T_BeamV1.0.pdf) ## Flashing the Device    [[TOC](#toc)] 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: ``` make flash BOARD=esp32-ttgo-t-beam ... ``` For detailed information about ESP32 as well as configuring and compiling RIOT for ESP32 boards, see \ref esp32_riot. */