mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
8101f52e3f
Signed-off-by: Yegor Yefremov <yegorslists@googlemail.com>
198 lines
9.1 KiB
Plaintext
198 lines
9.1 KiB
Plaintext
/*
|
|
* 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 <yegorslists@googlemail.com>
|
|
|
|
## <a name="toc"> Table of Contents </a>
|
|
|
|
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)
|
|
|
|
## <a name="overview"> Overview </a> [[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
|
|
```
|
|
|
|
## <a name="hardware"> Hardware </a> [[TOC](#toc)]
|
|
|
|
This section describes
|
|
|
|
- the [MCU](#mcu),
|
|
- the default [board configuration](#board_configuration),
|
|
- [optional hardware configurations](#optional_hardware),
|
|
- the [board pinout](#pinout).
|
|
|
|
### <a name="mcu"> MCU </a> [[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".
|
|
|
|
<center>
|
|
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 <br> 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 <br> 44 mA @ 160 MHz <br> 31 mA @ 80 MHz <br> 5 uA in deep sleep mode | yes <br> yes <br> yes <br> 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) <br> [Technical Reference](https://www.espressif.com/sites/default/files/documentation/esp32_technical_reference_manual_en.pdf) | |
|
|
</center>
|
|
|
|
### <a name="board_configuration"> Board Configuration </a> [[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
|
|
|
|
<center>
|
|
\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,<br>GPIO25, GPIO32, GPIO33, GPIO34,<br>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"
|
|
</center>
|
|
|
|
TTGO- T-Beam V1.0
|
|
|
|
<center>
|
|
\anchor esp32_ttgo_t_beam_v1_0_table_board_configuration
|
|
Function | GPIOs | Remarks |Configuration
|
|
:---------------|:-------|:--------|:----------------------------------
|
|
BUTTON0 | GPIO38 | low active | |
|
|
ADC | GPIO0, GPIO2, GPIO4, GPIO13,<br>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"
|
|
</center>
|
|
|
|
<br>
|
|
@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".
|
|
|
|
### <a name="pinout"> Board Pinout </a> [[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)
|
|
|
|
## <a name="flashing"> Flashing the Device </a> [[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.
|
|
*/
|