From 692d6725e2de74d6aa10e5f768944b59382a636d Mon Sep 17 00:00:00 2001 From: Schorcht Date: Mon, 8 Oct 2018 12:20:49 +0200 Subject: [PATCH] boards: add esp32-wemos-lolin-d32-pro --- boards/esp32-wemos-lolin-d32-pro/Makefile | 5 + boards/esp32-wemos-lolin-d32-pro/Makefile.dep | 1 + .../Makefile.features | 14 ++ .../Makefile.include | 6 + boards/esp32-wemos-lolin-d32-pro/doc.txt | 174 ++++++++++++++++ .../include/arduino_board.h | 82 ++++++++ .../esp32-wemos-lolin-d32-pro/include/board.h | 84 ++++++++ .../include/gpio_params.h | 45 ++++ .../include/periph_conf.h | 194 ++++++++++++++++++ 9 files changed, 605 insertions(+) create mode 100644 boards/esp32-wemos-lolin-d32-pro/Makefile create mode 100644 boards/esp32-wemos-lolin-d32-pro/Makefile.dep create mode 100644 boards/esp32-wemos-lolin-d32-pro/Makefile.features create mode 100644 boards/esp32-wemos-lolin-d32-pro/Makefile.include create mode 100644 boards/esp32-wemos-lolin-d32-pro/doc.txt create mode 100644 boards/esp32-wemos-lolin-d32-pro/include/arduino_board.h create mode 100644 boards/esp32-wemos-lolin-d32-pro/include/board.h create mode 100644 boards/esp32-wemos-lolin-d32-pro/include/gpio_params.h create mode 100644 boards/esp32-wemos-lolin-d32-pro/include/periph_conf.h diff --git a/boards/esp32-wemos-lolin-d32-pro/Makefile b/boards/esp32-wemos-lolin-d32-pro/Makefile new file mode 100644 index 0000000000..ca00a69d9c --- /dev/null +++ b/boards/esp32-wemos-lolin-d32-pro/Makefile @@ -0,0 +1,5 @@ +MODULE = board + +DIRS = $(RIOTBOARD)/common/esp32 + +include $(RIOTBASE)/Makefile.base diff --git a/boards/esp32-wemos-lolin-d32-pro/Makefile.dep b/boards/esp32-wemos-lolin-d32-pro/Makefile.dep new file mode 100644 index 0000000000..29d6c99ba8 --- /dev/null +++ b/boards/esp32-wemos-lolin-d32-pro/Makefile.dep @@ -0,0 +1 @@ +include $(RIOTBOARD)/common/esp32/Makefile.dep diff --git a/boards/esp32-wemos-lolin-d32-pro/Makefile.features b/boards/esp32-wemos-lolin-d32-pro/Makefile.features new file mode 100644 index 0000000000..6c55a2ddae --- /dev/null +++ b/boards/esp32-wemos-lolin-d32-pro/Makefile.features @@ -0,0 +1,14 @@ +# common board and CPU features +include $(RIOTBOARD)/common/esp32/Makefile.features + +# additional features provided by the board +FEATURES_PROVIDED += periph_adc +FEATURES_PROVIDED += periph_dac +FEATURES_PROVIDED += periph_i2c +FEATURES_PROVIDED += periph_pwm +FEATURES_PROVIDED += periph_spi + +# unique features provided by the board +FEATURES_PROVIDED += esp_spi_ram + +FEATURES_PROVIDED += arduino diff --git a/boards/esp32-wemos-lolin-d32-pro/Makefile.include b/boards/esp32-wemos-lolin-d32-pro/Makefile.include new file mode 100644 index 0000000000..3df3e4a4d5 --- /dev/null +++ b/boards/esp32-wemos-lolin-d32-pro/Makefile.include @@ -0,0 +1,6 @@ +PSEUDOMODULES += esp_lolin_tft + +USEMODULE += boards_common_esp32 +USEMODULE += esp_spi_ram + +include $(RIOTBOARD)/common/esp32/Makefile.include diff --git a/boards/esp32-wemos-lolin-d32-pro/doc.txt b/boards/esp32-wemos-lolin-d32-pro/doc.txt new file mode 100644 index 0000000000..6d958c26e8 --- /dev/null +++ b/boards/esp32-wemos-lolin-d32-pro/doc.txt @@ -0,0 +1,174 @@ +/* + * 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_wemos-lolin-d32-pro Wemos LOLIN D32 Pro + * @ingroup boards_esp32 + * @brief Support for Wemos LOLIN D32 Pro + * @author Gunar Schorcht + +## 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)] + +Wemos LOLIN D32 Pro is a development board that uses the ESP32-WROVER module which has a built-in 4 MByte SPI RAM. Most important features of the board are + +- Micro-SD card interface +- TFT display interface +- SPI RAM 4 MByte + +Wemos LOLIN D32 Pro belongs to the class of general purpose boards where most ESP32 pins are broken out for easier access. + +\htmlonly\endhtmlonly +@image html "https://wiki.wemos.cc/_media/products:d32:d32_pro_v2.0.0_1_16x9.jpg" "Wemos LOLIN D32 PRO" + +## 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 | 520 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 | no +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)] + +The board for the Wemos LOLIN D32 Pro has the following on-board components: + +- 1 x LED +- 1 x Micro SD card interface +- 1 x TFT display connector + +The following table shows the default board configuration, which is sorted according to the defined functionality of GPIOs. This configuration can be overridden by an \ref esp32_app_spec_conf "application-specific configuration". + +
+\anchor esp32_wemos-lolin-d32-pro_table_board_configuration +Pin | Default Configuration* | Optional Configuration* | Remarks / Prerequisites | Configuration +:------|:-----------------|:--------------------|:--------------|:------------- +GPIO22 | I2C_DEV(0):SCL | | | \ref esp32_i2c_interfaces "I2C Interfaces" +GPIO21 | I2C_DEV(0):SDA | | | \ref esp32_i2c_interfaces "I2C Interfaces" +GPIO18 | SPI_DEV(0):SCK | | | \ref esp32_spi_interfaces "SPI Interfaces" +GPIO19 | SPI_DEV(0):MISO | | | \ref esp32_spi_interfaces "SPI Interfaces" +GPIO23 | SPI_DEV(0):MOSI | | | \ref esp32_spi_interfaces "SPI Interfaces" +GPIO5 | SPI_DEV(0):CS0 / LED0 | | | \ref esp32_spi_interfaces "SPI Interfaces" +GPIO4 | SPI_DEV(0):CS1 | SD Card CS | when module [sdcard_spi](https://riot-os.org/api/group__drivers__sdcard__spi.html) is used | \ref esp32_spi_interfaces "SPI Interfaces" +GPIO1 | UART_DEV(0):TxD | | Console (configuration is fixed) | \ref esp32_uart_interfaces "UART interfaces" +GPIO3 | UART_DEV(0):RxD | | Console (configuration is fixed) | \ref esp32_uart_interfaces "UART interfaces" +GPIO36 | ADC_LINE(0) | | | \ref esp32_adc_channels "ADC Channels" +GPIO39 | ADC_LINE(1) | | | \ref esp32_adc_channels "ADC Channels" +GPIO34 | ADC_LINE(2) | | | \ref esp32_adc_channels "ADC Channels" +GPIO35 | ADC_LINE(3) | | VBat measurement (GPIO is not broken out) | \ref esp32_adc_channels "ADC Channels" +GPIO32 | ADC_LINE(4) | TFT_LED | when TFT is connected | \ref esp32_adc_channels "ADC Channels" +GPIO33 | ADC_LINE(5) | TFT_RESET| when TFT is connected | \ref esp32_adc_channels "ADC Channels" +GPIO25 | DAC_LINE(0) | | | \ref esp32_dac_channels "DAC Channels" +GPIO26 | DAC_LINE(1) | | | \ref esp32_dac_channels "DAC Channels" +GPIO0 | PWM_DEV(0):0| MRF24J40/ENC28J60 RESET | when module [mrf24j40](https://riot-os.org/api/group__drivers__mrf24j40.html)/[enc2860](https://riot-os.org/api/group__drivers__enc28j60.html) is used | \ref esp32_pwm_channels "PWM Channels" +GPIO2 | PWM_DEV(0):1| MRF24J40/ENC28J60 CS | when module [mrf24j40](https://riot-os.org/api/group__drivers__mrf24j40.html)/[enc2860](https://riot-os.org/api/group__drivers__enc28j60.html) is used | \ref esp32_pwm_channels "PWM Channels" +GPIO13 | - | MRF24J40/ENC28J60 INT | when module [mrf24j40](https://riot-os.org/api/group__drivers__mrf24j40.html)/[enc2860](https://riot-os.org/api/group__drivers__enc28j60.html) is used | | +GPIO15 | - | | | | +GPIO12 | - | TS_CS | when TFT is connected | | +GPIO14 | - | TFT_CS | when TFT is connected | | +GPIO27 | - | TFT_DC | when TFT is connected | | +
+ +* Default configuration cannot be used or is not available at all when optional configuration is used. For example, when the TFT is connected, GPIO32 is used as **TFT_LED** signal and ADC_LINE(4) is not available. + +@note When the TFT display is connected, add the following line to the makefile of the application to enable the according default board and peripheral configuration:
+``` +USEMODULE += esp_lolin_tft +``` + +For detailed information about the configuration of ESP32 boards, see section \ref esp32_comm_periph "Common Peripherals". + +### Optional Hardware Configurations    [[TOC](#toc)] + +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_app_spec_conf "application-specific configuration" to use such modules: + +``` +#ifdef BOARD_ESP32_WEMOS_LOLIN_D32_PRO + +#if MODULE_MRF24J40 +#define MRF24J40_PARAM_CS GPIO15 /* MRF24J40 CS signal */ +#define MRF24J40_PARAM_RESET GPIO2 /* MRF24J40 RESET signal */ +#define MRF24J40_PARAM_INT GPIO13 /* MRF24J40 INT signal */ +#endif + +#if MODULE_ENC28J80 +#define ENC28J80_PARAM_CS GPIO15 /* ENC28J80 CS signal */ +#define ENC28J80_PARAM_RESET GPIO2 /* ENC28J80 RESET signal */ +#define ENC28J80_PARAM_INT GPIO13 /* ENC28J80 INT signal */ +endif + +#endif +``` +For other parameters, the default values defined by the drivers can be used. + +@note +- Only a few GPIOs are available for external hardware on the Wemos LOLIN D32 PRO. Therefore, MRF24J40 and ENC28J60 based modules use the same GPIOs and only one of these modules can be used simultaneously. +- The **RESET** signal of MRF24J40 and ENC28J60 based modules can also be connected to the **RST** pin of the board (see \ref esp32_wemos-lolin-d32-pro_pinout "pinout") to keep the configured GPIO free for other purposes. + +### Board Pinout    [[TOC](#toc)] + +The following picture shows the pinout of WEMOS LOLIN D32 PRO board as defined by the default board configuration. 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 \ref esp32_wemos-lolin-d32-pro_table_board_configuration "optional functions" in table board configuration. + +The corresponding board schematic can be found [here](https://wiki.wemos.cc/_media/products:d32:sch_d32_pro_v2.0.0.pdf). + +\anchor esp32_wemos-lolin-d32-pro_pinout +@image html "https://gitlab.com/gschorcht/RIOT.wiki-Images/raw/master/esp32/Wemos_LOLIN_D32_PRO_pinout.png?inline=false" "Wemos LOLIN D32 PRO pinout" + +## 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 using the programming port and type: +``` +make flash BOARD=esp32-wemos-lolin-d32-pro ... +``` +For detailed information about ESP32 as well as configuring and compiling RIOT for ESP32 boards, see \ref esp32_riot. + +*/ diff --git a/boards/esp32-wemos-lolin-d32-pro/include/arduino_board.h b/boards/esp32-wemos-lolin-d32-pro/include/arduino_board.h new file mode 100644 index 0000000000..aaf4515752 --- /dev/null +++ b/boards/esp32-wemos-lolin-d32-pro/include/arduino_board.h @@ -0,0 +1,82 @@ +/* + * 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. + */ + +/** + * @ingroup boards_esp32_wemos-lolin-d32-pro + * @{ + * + * @file + * @brief Board specific configuration for the Arduino API + * + * @author Gunar Schorcht + */ + +#ifndef ARDUINO_BOARD_H +#define ARDUINO_BOARD_H + +#include "periph/gpio.h" +#include "periph/adc.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @brief The on-board LED is connected to pin 2 on this board + */ +#define ARDUINO_LED (10) + +/** + * @brief Look-up table for the Arduino's digital pins + */ +static const gpio_t arduino_pinmap[] = { + GPIO3, /* ARDUINO_PIN_0 (RxD) */ + GPIO1, /* ARDUINO_PIN_1 (TxD) */ + + GPIO4, /* ARDUINO_PIN_2 */ + GPIO0, /* ARDUINO_PIN_3 (PWM) */ + GPIO13, /* ARDUINO_PIN_4 */ + GPIO2, /* ARDUINO_PIN_5 (PWM) */ + GPIO15, /* ARDUINO_PIN_6 (PWM) */ + GPIO25, /* ARDUINO_PIN_7 */ + GPIO26, /* ARDUINO_PIN_8 */ + GPIO32, /* ARDUINO_PIN_9 (PWM) */ + + GPIO5, /* ARDUINO_PIN_10 (CS0 / PWM) */ + GPIO23, /* ARDUINO_PIN_11 (MOSI / PWM) */ + GPIO19, /* ARDUINO_PIN_12 (MISO) */ + GPIO18, /* ARDUINO_PIN_13 (SCK) */ + + GPIO36, /* ARDUINO_PIN_A0 */ + GPIO39, /* ARDUINO_PIN_A1 */ + GPIO34, /* ARDUINO_PIN_A2 */ + GPIO35, /* ARDUINO_PIN_A3 */ + + GPIO21, /* ARDUINO_PIN_A4 (SDA) */ + GPIO22, /* ARDUINO_PIN_A5 (SCL) */ +}; + +/** + * @brief Look-up table for the Arduino's analog pins + */ +static const adc_t arduino_analog_map[] = { + GPIO36, /* ARDUINO_PIN_A0 */ + GPIO39, /* ARDUINO_PIN_A1 */ + GPIO34, /* ARDUINO_PIN_A2 */ + GPIO35, /* ARDUINO_PIN_A3 */ + + GPIO27, /* ARDUINO_PIN_A4 (SDA) */ + GPIO33, /* ARDUINO_PIN_A5 (SCL) */ +}; + +#ifdef __cplusplus +} +#endif + +#endif /* ARDUINO_BOARD_H */ +/** @} */ diff --git a/boards/esp32-wemos-lolin-d32-pro/include/board.h b/boards/esp32-wemos-lolin-d32-pro/include/board.h new file mode 100644 index 0000000000..16875deec4 --- /dev/null +++ b/boards/esp32-wemos-lolin-d32-pro/include/board.h @@ -0,0 +1,84 @@ +/* + * 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. + */ + +/** + * @ingroup boards_esp32_wemos-lolin-d32-pro + * @brief Board specific definitions for Wemos LOLIN D32 Pro + * @{ + * + * Wemos LOLIN D32 Pro is a development board that uses the ESP32-WROVER + * module which has a built-in 4 MByte SPI RAM. Most important + * features of the board are + * + * - Micro-SD card interface + * - LCD interface + * - SPI RAM 4 MByte + * + * Furthermore, most GPIOs are broken out for extension. + * + * When the TFT display is connected, add + * ``` + * USEMODULE += esp_lolin_tft + * ``` + * to the makefile of the application to use the according default board + * configuration. + * + * For detailed information about the configuration of ESP32 boards, see + * section \ref esp32_comm_periph "Common Peripherals". + * + * @note + * Most definitions can be overridden by an \ref esp32_app_spec_conf + * "application-specific board configuration". + * + * @file + * @author Gunar Schorcht + */ + +#ifndef BOARD_H +#define BOARD_H + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + * @name LED (on-board) configuration + * @{ + */ +#define LED0_PIN GPIO5 +#define LED0_ACTIVE (0) /* LED is low active */ +/** @} */ + +/** + * @name SD card interface configuration + * + * SD card interface uses SPI_DEV(0) on this board. This configuration cannot + * be overriden. + * @{ + */ +#if MODULE_SDCARD_SPI +#define SDCARD_SPI_PARAM_SPI SPI_DEV(0) /**< SPI_DEV(0) is used (fixed) */ +#define SDCARD_SPI_PARAM_CLK SPI0_SCK /**< HSPI SCK is used (fixed) */ +#define SDCARD_SPI_PARAM_MOSI SPI0_MOSI /**< HSPI MOSI is used (fixed) */ +#define SDCARD_SPI_PARAM_MISO SPI0_MISO /**< HSPI MISO is used (fixed) */ +#define SDCARD_SPI_PARAM_CS SPI0_CS1 /**< HSPI CS1 is used (fixed) */ +#define SDCARD_SPI_PARAM_POWER GPIO_UNDEF /**< power control is not used (fixed) */ +#endif +/** @} */ + +#ifdef __cplusplus +} /* end extern "C" */ +#endif + +/* include common board definitions as last step */ +#include "board_common.h" + +#endif /* BOARD_H */ +/** @} */ diff --git a/boards/esp32-wemos-lolin-d32-pro/include/gpio_params.h b/boards/esp32-wemos-lolin-d32-pro/include/gpio_params.h new file mode 100644 index 0000000000..25ab3cfd47 --- /dev/null +++ b/boards/esp32-wemos-lolin-d32-pro/include/gpio_params.h @@ -0,0 +1,45 @@ +/* + * 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. + */ + +#ifndef GPIO_PARAMS_H +#define GPIO_PARAMS_H + +/** + * @ingroup boards_esp32_wemos-lolin-d32-pro + * @brief Board specific configuration of direct mapped GPIOs + * @file + * @author Gunar Schorcht + * @{ + */ + +#include "board.h" +#include "saul/periph.h" + +#ifdef __cplusplus +extern "C" { +#endif + +/** + * @brief LED configuration + */ +static const saul_gpio_params_t saul_gpio_params[] = +{ + { + .name = "LED", + .pin = LED0_PIN, + .mode = GPIO_OUT, + .flags = (SAUL_GPIO_INVERTED | SAUL_GPIO_INIT_CLEAR) + } +}; + +#ifdef __cplusplus +} +#endif + +#endif /* GPIO_PARAMS_H */ +/** @} */ diff --git a/boards/esp32-wemos-lolin-d32-pro/include/periph_conf.h b/boards/esp32-wemos-lolin-d32-pro/include/periph_conf.h new file mode 100644 index 0000000000..0724047463 --- /dev/null +++ b/boards/esp32-wemos-lolin-d32-pro/include/periph_conf.h @@ -0,0 +1,194 @@ +/* + * 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. + */ + +/** + * @ingroup boards_esp32_wemos-lolin-d32-pro + * @brief Peripheral MCU configuration for Wemos LOLIN D32 Pro + * @{ + * + * + * Wemos LOLIN D32 Pro is a development board that uses the ESP32-WROVER + * module which has a built-in 4 MByte SPI RAM. Most important + * features of the board are + * + * - Micro-SD card interface + * - LCD interface + * - SPI RAM 4 MByte + * + * Furthermore, most GPIOs are broken out for extension. + * + * When the TFT display is connected, add + * ``` + * USEMODULE += esp_lolin_tft + * ``` + * to the makefile of the application to use the according default board + * configuration. + * + * For detailed information about the configuration of ESP32 boards, see + * section \ref esp32_comm_periph "Common Peripherals". + * + * @note + * Most definitions can be overridden by an \ref esp32_app_spec_conf + * "application-specific board configuration". + * + * @author Gunar Schorcht + * @file + */ + +#ifndef PERIPH_CONF_H +#define PERIPH_CONF_H + +#include + +#ifdef __cplusplus + extern "C" { +#endif + +/** + * @name ADC and DAC channel configuration + * @{ + */ + +/** + * @brief Declaration of GPIOs that can be used as ADC channels + * + * GPIO35 is used to measure V_BAT and is therefore not broken out. + * + * @note As long as the GPIOs listed in ADC_GPIOS are not initialized as ADC + * channels with the ```adc_init``` function, they can be used for other + * purposes. + */ +#ifndef ADC_GPIOS +#ifndef MODULE_ESP_LOLIN_TFT +#define ADC_GPIOS { GPIO36, GPIO39, GPIO34, GPIO35, GPIO32, GPIO33 } +#else +#define ADC_GPIOS { GPIO36, GPIO39, GPIO34, GPIO35 } +#endif +#endif + +/** + * @brief Declaration of GPIOs that can be used as DAC channels + * + * @note As long as the GPIOs listed in DAC_GPIOS are not initialized as DAC + * channels with the ```dac_init``` function, they can be used for other + * purposes. + */ +#ifndef DAC_GPIOS +#define DAC_GPIOS { GPIO25, GPIO26 } +#endif +/** @} */ + + +/** + * @name I2C configuration + * + * Only I2C interface I2C_DEV(0) is used. + * + * @note The GPIOs listed in the configuration are only initialized as I2C + * signals when module ```perpih_i2c``` is used. Otherwise they are not + * allocated and can be used for other purposes. + * + * @{ + */ +#ifndef I2C0_SPEED +#define I2C0_SPEED I2C_SPEED_FAST /**< I2C bus speed of I2C_DEV(0) */ +#endif +#ifndef I2C0_SCL +#define I2C0_SCL GPIO22 /**< SCL signal of I2C_DEV(0) [UEXT1] */ +#endif +#ifndef I2C0_SDA +#define I2C0_SDA GPIO21 /**< SDA signal of I2C_DEV(0) [UEXT1] */ +#endif +/** @} */ + + +/** + * @name PWM channel configuration + * + * @note As long as the according PWM device is not initialized with + * the ```pwm_init```, the GPIOs declared for this device can be used + * for other purposes. + * + * @{ + */ +/** PWM channels for device PWM_DEV(0) */ +#ifndef PWM0_GPIOS +#define PWM0_GPIOS { GPIO0, GPIO2 } +#endif + +/** PWM_DEV(1) is not used */ +#ifndef PWM1_GPIOS +#define PWM1_GPIOS { } +#endif +/** @} */ + + + +/** + * @name SPI configuration + * + * @note The GPIOs listed in the configuration are first initialized as SPI + * signals when the corresponding SPI interface is used for the first time + * by either calling the ```spi_init_cs``` function or the ```spi_acquire``` + * function. That is, they are not allocated as SPI signals before and can + * be used for other purposes as long as the SPI interface is not used. + * + * @{ + */ +#ifndef SPI0_DEV +#define SPI0_DEV VSPI /**< VSPI is used as SPI_DEV(0) */ +#endif +#ifndef SPI0_SCK +#define SPI0_SCK GPIO18 /**< VSPI SCK */ +#endif +#ifndef SPI0_MISO +#define SPI0_MISO GPIO19 /**< VSPI MISO */ +#endif +#ifndef SPI0_MOSI +#define SPI0_MOSI GPIO23 /**< VSPI MOSI */ +#endif +#ifndef SPI0_CS0 +#define SPI0_CS0 GPIO5 /**< VSPI CS0 */ +#endif + +#ifdef MODULE_SDCARD_SPI +#define SPI0_CS1 GPIO4 /**< VSPI CS1 / SD card [TF_CS] */ +#endif + +#ifdef MODULE_ESP_LOLIN_TFT +#define SPI0_CS2 GPI14 /**< VSPI CS2 / TFT [TFT_CS] */ +#define SPI0_CS3 GPI12 /**< VSPI CS3 / TFT [TS_CS] */ +#endif +/** @} */ + + +/** + * @name UART configuration + * + * ESP32 provides 3 UART interaces at maximum: + * + * UART_DEV(0) uses fixed standard configuration.
+ * UART_DEV(1) is not used.
+ * UART_DEV(2) is not used.
+ * + * @{ + */ +#define UART0_TXD GPIO1 /**< direct I/O pin for UART_DEV(0) TxD, can't be changed */ +#define UART0_RXD GPIO3 /**< direct I/O pin for UART_DEV(0) RxD, can't be changed */ +/** @} */ + + +#ifdef __cplusplus +} /* end extern "C" */ +#endif + +/* include common board definitions as last step */ +#include "periph_conf_common.h" + +#endif /* PERIPH_CONF_H */ +/** @} */