1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-17 10:12:45 +01:00
19417: boards/esp32c3-wemos-mini: add support for Wemos ESP32-C3 mini r=benpicco a=gschorcht

### Contribution description

This PR provides the support for the [Wemos ESP32-C3 mini](https://www.wemos.cc/en/latest/c3/c3_mini.html) board.

### Testing procedure

The board should work for provided features.

The board was already tested with:
- [x] `tests/driver_sht3x` using I2C
- [x] `tests/driver_l3gxxxx` using SPI
- [x] `tests/periph_adc`
- [x] `tests/periph_pwm`
- [ ] `tests/driver_ws281x`

### Issues/PRs references


Co-authored-by: Gunar Schorcht <gunar@schorcht.net>
This commit is contained in:
bors[bot] 2023-03-30 16:51:46 +00:00 committed by GitHub
commit a7c857dd60
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
12 changed files with 741 additions and 0 deletions

View File

@ -0,0 +1,51 @@
# Copyright (c) 2020 HAW Hamburg
# 2022 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.
config BOARD
default "esp32c3-wemos-mini" if BOARD_ESP32C3_WEMOS_MINI
config BOARD_ESP32C3_WEMOS_MINI
bool
default y
select BOARD_COMMON_ESP32C3
select CPU_MODEL_ESP32C3_FH4
# select HAS_ARDUINO
select HAS_ESP_JTAG
select HAS_PERIPH_ADC
select HAS_PERIPH_I2C
select HAS_PERIPH_PWM
select HAS_PERIPH_SPI
select MODULE_ESP32C3_WEMOS_MINI_V1_0_0 if BOARD_VERSION_ESP32C3_WEMOS_MINI_V1_0_0
select MODULE_ESP32C3_WEMOS_MINI_V2_1_0 if BOARD_VERSION_ESP32C3_WEMOS_MINI_V2_1_0
choice
bool "Wemos ESP32-C3 mini board version"
default BOARD_VERSION_ESP32C3_WEMOS_MINI_V2_1_0
config BOARD_VERSION_ESP32C3_WEMOS_MINI_V1_0_0
bool "Version 1.0.0"
config BOARD_VERSION_ESP32C3_WEMOS_MINI_V2_1_0
bool "Version 2.1.0"
help
There are different versions on the market which differ in the pin
layout for ADC channels and the SPI interface. In addition,
version 2.1.0 has an RGB LED connected to GPIO7 instead of an LED.
Select your version for correct peripheral configuration. If your
board has a RGB LED, it is version 2.1.0 or newer, otherwise it is
version 1.0.0
endchoice
config MODULE_ESP32C3_WEMOS_MINI_V1_0_0
bool
help
Indicates that Wemos ESP32-C3 mini board version v1.0.0 is used.
config MODULE_ESP32C3_WEMOS_MINI_V2_1_0
bool
help
Indicates that Wemos ESP32-C3 mini board version v2.1.0 is used.
source "$(RIOTBOARD)/common/esp32c3/Kconfig"

View File

@ -0,0 +1,5 @@
MODULE = board
DIRS = $(RIOTBOARD)/common/esp32c3
include $(RIOTBASE)/Makefile.base

View File

@ -0,0 +1,10 @@
ifeq (,$(filter stdio_% slipdev_stdio,$(USEMODULE)))
USEMODULE += stdio_usb_serial_jtag
endif
ifeq (,$(filter esp32c3_wemos_mini_v%,$(USEMODULE)))
# use Wemos ESP32-C3 min version V2.1.0 by default
USEMODULE += esp32c3_wemos_mini_v2_1_0
endif
include $(RIOTBOARD)/common/esp32c3/Makefile.dep

View File

@ -0,0 +1,15 @@
CPU_MODEL = esp32c3_fh4
# common board and CPU features
include $(RIOTBOARD)/common/esp32c3/Makefile.features
# additional features provided by the board
FEATURES_PROVIDED += periph_adc
FEATURES_PROVIDED += periph_i2c
FEATURES_PROVIDED += periph_pwm
FEATURES_PROVIDED += periph_spi
# unique features provided by the board
FEATURES_PROVIDED += esp_jtag
#FEATURES_PROVIDED += arduino

View File

@ -0,0 +1,6 @@
PORT_LINUX ?= /dev/ttyACM0
PSEUDOMODULES += esp32c3_wemos_mini_v1_0_0
PSEUDOMODULES += esp32c3_wemos_mini_v2_1_0
include $(RIOTBOARD)/common/esp32c3/Makefile.include

View File

@ -0,0 +1,191 @@
/*
* 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_esp32c3_wemos_mini Wemos ESP32-C3 mini
* @ingroup boards_esp32c3
* @brief Support for generic ESP32-C3 boards
* @author Gunar Schorcht <gunar@schorcht.net>
\section esp32c3_wemos_mini Wemos ESP32-C3 mini
## Table of Contents {#esp32c3_wemos_mini_toc}
1. [Overview](#esp32c3_wemos_mini_overview)
2. [Hardware](#esp32c3_wemos_mini_hardware)
1. [MCU](#esp32c3_wemos_mini_mcu)
2. [Board Configuration](#esp32c3_wemos_mini_board_configuration)
3. [Board Pinout](#esp32c3_wemos_mini_pinout)
3. [Flashing the Device](#esp32c3_wemos_mini_flashing)
## Overview {#esp32c3_wemos_mini_overview}
The Wemos ESP32-C3 mini board is an interesting development kit as it uses
in the stackable Wemos LOLIN D1 Mini format. Thus, all [shields for Wemos D1 mini]
(https://docs.wemos.cc/en/latest/d1_mini_shield/index.html) for ESP8266
can also be used with ESP32-C3. Examples for such shields are:
- Micro SD-Card Shield
- MRF24J40 IEEE 802.15.4 radio Shield
- Button Shield
- RGB LED Shield
- OLED Display Shield
- ...
This makes it possible to create different hardware configurations without
the need for a soldering iron or a breadboard.
@image html "https://www.wemos.cc/en/latest/_images/c3_mini_v2.1.0_1_16x16.jpg" "Wemos ESP32-C3 mini board" width=250px
This stackable platform was tested in an RIOT application with:
- MRF24J40 IEEE 802.15.4 radio Shield (contact gunar@schorcht.net for more information)
- [BMP180 Pressure Sensor Shield]
This application is a good example how easy it is with this board to create
different hardware applications.
@image html "https://gitlab.com/gschorcht/RIOT.wiki-Images/raw/master/esp32/Wemos_ESP32-C3_mini_application.jpg" "RIOT application with MRF24J40 Radio and a BMP180 Pressure Sensor" width=450px
[Back to table of contents](#esp32c3_wemos_mini_toc)
## Hardware {#esp32c3_wemos_mini_hardware}
This section describes
- the [MCU](#esp32c3_wemos_mini_mcu),
- the default [board configuration](#esp32c3_wemos_mini_board_configuration),
- the [board pinout](#esp32c3_wemos_mini_pinout).
[Back to table of contents](#esp32c3_wemos_mini_toc)
### MCU {#esp32c3_wemos_mini_mcu}
Most features of the board are provided by the ESP32-C3 SoC. For detailed
information about the ESP32-C3 variant (family) and ESP32x SoCs,
see section \ref esp32_mcu_esp32 "ESP32 SoC Series".
[Back to table of contents](#esp32c3_wemos_mini_toc)
### Board Configuration {#esp32c3_wemos_mini_board_configuration}
The Wemos ESP32-C3 mini board has no special hardware on board with the
exception of a single pin RGB-LED.
There are two board versions available on the market with a different pinout
of the ADC channels and the SPI interface. Which version is used is
determined by activating a pseudo module for the corresponding version:
- v1.0.0, module `esp32c3_wemos_mini_v1_0_0`
- v2.1.0, module `esp32c3_wemos_mini_v2_1_0` (default)
To specify which board version is used, simply add the variable
definition `USEMODULE=...` to the make command line, for example:
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
USEMODULE=esp32c3_wemos_mini_v1_0_0 BOARD=esp32c3-wemos-min make ...
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
If the board version is not specified, version v2.1.0 is used by default.
Almost all GPIOs are broken out and can be used for different peripherals:
- 6 x ADC channels at maximum
- 1 x SPI
- 1 x I2C
- 1 x UART
- 2 x PWM channels
However, since the number of GPIOs of the ESP32-C3 SoC is very limited, some
GPIOs are used in multiple peripheral configurations but can only be used for
one peripheral at a time. For example, GPIO4 is used in the ADC channel
configuration and in the MOSI signal configuration for SPI_DEV(0). This is
possible because GPIOs are only used for a specific peripheral interface when
either
- the corresponding peripheral module is used, e.g. `periph_spi` or
- the corresponding init function is called, e.g. `adc_init`
That is, the purpose for which a GPIO is used depends on which module
or function is used first. For example, if module `periph_spi` is not used,
the GPIOs listed in SPI configuration can be used for other purposes, that is,
GPIO4 can be used as ADC channel.
The following table shows the default board configuration depending on used
board version, which is sorted according to the defined functionality of GPIOs.
This configuration can be overridden by \ref esp32_application_specific_configurations
"application-specific configurations".
<center>
Function | v1.0.0 | v2.1.0 | Remarks | Configuration
:---------------|:-------|:-------|:--------|:---------------------
BUTTON0 | GPIO9 | GPIO9 | | |
ADC | GPIO0 ... GPIO5 | GPIO0 ... GPIO5 | | see \ref esp32_adc_channels "ADC Channels"
I2C_DEV(0):SCL | GPIO10 | GPIO10 | | \ref esp32_i2c_interfaces "I2C Interfaces"
I2C_DEV(0):SDA | GPIO8 | GPIO8 | | \ref esp32_i2c_interfaces "I2C Interfaces"
LED0 | GPIO7 | - | | |
PWM_DEV(0) | GPIO1, GPIO6, GPIO7 | GPIO2, GPIO6 | | \ref esp32_pwm_channels "PWM Channels"
RGB-LED | - | GPIO7 | supported by driver module `ws281x` | |
SPI_DEV(0):CLK | GPIO2 | GPIO1 | SPI2_HOST (FSPI) is used | \ref esp32_spi_interfaces "SPI Interfaces"
SPI_DEV(0):MISO | GPIO3 | GPIO0 | SPI2_HOST (FSPI) is used | \ref esp32_spi_interfaces "SPI Interfaces"
SPI_DEV(0):MOSI | GPIO4 | GPIO4 | SPI2_HOST (FSPI) is used | \ref esp32_spi_interfaces "SPI Interfaces"
SPI_DEV(0):CS0 | GPIO5 | GPIO5 | SPI2_HOST (FSPI) is used | \ref esp32_spi_interfaces "SPI Interfaces"
UART_DEV(0):TxD | GPIO21 | GPIO21 | Console (configuration is fixed) | \ref esp32_uart_interfaces "UART interfaces"
UART_DEV(0):RxD | GPIO20 | GPIO20 | Console (configuration is fixed) | \ref esp32_uart_interfaces "UART interfaces"
</center>
\n
@note The configuration of ADC channels contains all ESP32-C3 GPIOs that could
be used as ADC channels.
For detailed information about the peripheral configurations of ESP32-C3
boards, see section \ref esp32_peripherals "Common Peripherals".
[Back to table of contents](#esp32c3_wemos_mini_toc)
### Board Pinout {#esp32c3_wemos_mini_pinout}
The following figures show the pinouts as configured by default board
definition.
@image html https://gitlab.com/gschorcht/RIOT.wiki-Images/-/raw/master/esp32/Wesos_ESP32-C3_mini_pinout.png "Wemos EPS32-C3 mini Pinout"
The corresponding board schematics can be found:
- [Wemos ESP32-C3 mini v1.0.0](https://www.wemos.cc/en/latest/_static/files/sch_c3_mini_v1.0.0.pdf)
- [Wemos ESP32-C3 mini v2.1.0](https://www.wemos.cc/en/latest/_static/files/sch_c3_mini_v2.1.0.pdf)
[Back to table of contents](#esp32c3_wemos_mini_toc)
## Flashing the Device {#esp32c3_wemos_mini_flashing}
The USB-C connector of the board is directly connected to the USB Serial/JTAG
interface of the ESP32-C3 SoC. It can be used to program the board and to debug
the application. Just connect the board to your host computer and use the
following command:
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
make flash BOARD=esp32c3-devkit ...
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
The make system will resets the board to restart the board into download mode.
In some special cases this reset does not work so that the programmer cannot
connect to the board and the flashing is aborted with a timeout:
```
Serial port /dev/ttyACM0
Connecting...
...
serial.serialutil.SerialTimeoutException: Write timeout
```
In this case, restart the board manually in download mode by pressing and
releasing the RESET button while holding down the BOOT button.
After flashing the board, it will still be in download mode. You have to press
the reset button (RST) to start your application.
For detailed information about ESP32-C3 as well as configuring and compiling
RIOT for ESP32-C3 boards, see \ref esp32_riot.
[Back to table of contents](#esp32c3_wemos_mini_toc)
*/

View File

@ -0,0 +1 @@
CONFIG_MODULE_STDIO_USB_SERIAL_JTAG=y

View File

@ -0,0 +1,42 @@
/*
* Copyright (C) 2022 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_esp32c3_wemos_mini
* @{
*
* @file
* @brief Board specific configuration for the Arduino API
*
* @author Gunar Schorcht <gunar@schorcht.net>
*/
#ifndef ARDUINO_BOARD_H
#define ARDUINO_BOARD_H
#include "arduino_board_common.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief The on-board LED (not available on board version 2.1.0)
*/
#ifdef MODULE_ESP32C3_WEMOS_MINI_V1_0_0
#define ARDUINO_LED (5)
#else /* MODULE_ESP32C3_WEMOS_MINI_V2_1_0 */
#define ARDUINO_LED (0)
#endif
#ifdef __cplusplus
}
#endif
#endif /* ARDUINO_BOARD_H */
/** @} */

View File

@ -0,0 +1,77 @@
/*
* Copyright (C) 2022 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_esp32c3_wemos_mini
* @{
*
* @file
* @brief Mapping from MCU pins to Arduino pins
*
* @author Gunar Schorcht <gunar@schorcht.net>
*/
#ifndef ARDUINO_PINMAP_H
#define ARDUINO_PINMAP_H
#include "periph/gpio.h"
#include "periph/adc.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* @name Mapping of MCU pins to Arduino pins
* @{
*/
#define ARDUINO_PIN_0 GPIO20 /**< Arduino Uno pin 0 (RxD) */
#define ARDUINO_PIN_1 GPIO21 /**< Arduino Uno pin 1 (TxD) */
#define ARDUINO_PIN_2 GPIO9 /**< Arduino Uno pin 2 */
#define ARDUINO_PIN_3 GPIO6 /**< Arduino Uno pin 3 (PWM) */
#define ARDUINO_PIN_4 GPIO_UNDEF /**< Arduino Uno pin 4 */
#ifdef MODULE_ESP32C3_WEMOS_MINI_V1_0_0
#define ARDUINO_PIN_5 GPIO7 /**< Arduino Uno pin 5 (PWM) */
#define ARDUINO_PIN_6 GPIO1 /**< Arduino Uno pin 6 (PWM) */
#define ARDUINO_PIN_7 GPIO0 /**< Arduino Uno pin 7 */
#else /* MODULE_ESP32C3_WEMOS_MINI_V2_1_0 */
#define ARDUINO_PIN_5 GPIO_UNDEF /**< Arduino Uno pin 5 (PWM) */
#define ARDUINO_PIN_6 GPIO2 /**< Arduino Uno pin 6 (PWM) */
#define ARDUINO_PIN_7 GPIO3 /**< Arduino Uno pin 7 */
#endif
#define ARDUINO_PIN_8 GPIO_UNDEF /**< Arduino Uno pin 8 */
#define ARDUINO_PIN_9 GPIO_UNDEF /**< Arduino Uno pin 9 (PWM) */
#ifdef MODULE_ESP32C3_WEMOS_MINI_V1_0_0
#define ARDUINO_PIN_10 GPIO5 /**< Arduino Uno pin 10 (CS0 / PWM) */
#define ARDUINO_PIN_11 GPIO4 /**< Arduino Uno pin 11 (MOSI / PWM) */
#define ARDUINO_PIN_12 GPIO3 /**< Arduino Uno pin 12 (MISO) */
#define ARDUINO_PIN_13 GPIO2 /**< Arduino Uno pin 13 (SCK) */
#else /* MODULE_ESP32C3_WEMOS_MINI_V2_1_0 */
#define ARDUINO_PIN_10 GPIO5 /**< Arduino Uno pin 10 (CS0 / PWM) */
#define ARDUINO_PIN_11 GPIO4 /**< Arduino Uno pin 11 (MOSI / PWM) */
#define ARDUINO_PIN_12 GPIO0 /**< Arduino Uno pin 12 (MISO) */
#define ARDUINO_PIN_13 GPIO1 /**< Arduino Uno pin 13 (SCK) */
#endif
#define ARDUINO_PIN_A0 GPIO0 /**< Arduino Uno pin A0 */
#define ARDUINO_PIN_A1 GPIO1 /**< Arduino Uno pin A1 */
#define ARDUINO_PIN_A2 GPIO2 /**< Arduino Uno pin A2 */
#define ARDUINO_PIN_A3 GPIO3 /**< Arduino Uno pin A3 */
#define ARDUINO_PIN_A4 GPIO4 /**< Arduino Uno pin A4 (SDA) */
#define ARDUINO_PIN_A5 GPIO5 /**< Arduino Uno pin A5 (SCL) */
/** @} */
#ifdef __cplusplus
}
#endif
#endif /* ARDUINO_PINMAP_H */
/** @} */

View File

@ -0,0 +1,98 @@
/*
* 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.
*/
/**
* @ingroup boards_esp32c3_wemos_mini
* @brief Board definitions for the Wemos ESP32-C3 mini board
* @{
*
* @file
* @author Gunar Schorcht <gunar@schorcht.net>
*/
#ifndef BOARD_H
#define BOARD_H
#include <stdint.h>
/**
* @name Button pin definitions
* @{
*/
/**
* @brief Default button GPIO pin definition
*
* The Wemos ESP32-C3 mini board has a BOOT button connected to GPIO9, which can
* be used as button during normal operation. Since the GPIO9 pin is pulled up,
* the button signal is inverted, i.e., pressing the button will give a
* low signal.
*/
#define BTN0_PIN GPIO9
/**
* @brief Default button GPIO mode definition
*
* Since the GPIO of the button is pulled up with an external resistor, the
* mode for the GPIO pin has to be GPIO_IN.
*/
#define BTN0_MODE GPIO_IN_PU
/**
* @brief Default interrupt flank definition for the button GPIO
*/
#ifndef BTN0_INT_FLANK
#define BTN0_INT_FLANK GPIO_FALLING
#endif
/**
* @brief Definition for compatibility with previous versions
*/
#define BUTTON0_PIN BTN0_PIN
/** @} */
/**
* @name LED (on-board) configuration
*
* LED configuration depends on Wemos ESP32-C3 mini board version:
*
* - v1.0.0 has one LED connected to GPIO7.
* - v2.1.0 has one 24-bit RGB-LED WS2812B connected to GPIO7.
* @{
*/
#ifdef MODULE_ESP32C3_WEMOS_MINI_V1_0_0
#define LED0_PIN GPIO7 /**< GPIO7 is used as LED Pin */
#define LED0_ACTIVE (1) /**< LED is HIGH active */
#else /* MODULE_ESP32C3_WEMOS_MINI_V2_1_0 */
#ifndef WS281X_PARAM_PIN
#define WS281X_PARAM_PIN (GPIO7) /**< GPIO pin connected to the data pin */
#endif
#ifndef WS281X_PARAM_NUMOF
#define WS281X_PARAM_NUMOF (1U) /**< Number of LEDs chained */
#endif
#endif
/** @} */
/* include common board definitions as last step */
#include "board_common.h"
#ifdef __cplusplus
extern "C" {
#endif
#ifdef __cplusplus
} /* end extern "C" */
#endif
#endif /* BOARD_H */
/** @} */

View File

@ -0,0 +1,53 @@
/*
* 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.
*/
#ifndef GPIO_PARAMS_H
#define GPIO_PARAMS_H
/**
* @ingroup boards_esp32c3_wemos_mini
* @brief Board specific configuration of direct mapped GPIOs
* @file
* @author Gunar Schorcht <gunar@schorcht.net>
* @{
*/
#include "board.h"
#include "saul/periph.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief LED and Button configuration
*/
static const saul_gpio_params_t saul_gpio_params[] =
{
{
.name = "BOOT",
.pin = BTN0_PIN,
.mode = BTN0_MODE,
.flags = SAUL_GPIO_INVERTED
},
#ifdef LED0_PIN
{
.name = "LED0",
.pin = LED0_PIN,
.mode = GPIO_OUT,
.flags = SAUL_GPIO_INIT_CLEAR
},
#endif
};
#ifdef __cplusplus
}
#endif
#endif /* GPIO_PARAMS_H */
/** @} */

View File

@ -0,0 +1,192 @@
/*
* 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.
*/
/**
* @ingroup boards_esp32c3_wemos_mini
* @brief Peripheral configurations for the Wemos ESP32-C3 mini board
* @{
*
* For detailed information about the peripheral configuration for ESP32-C3
* boards, see section \ref esp32_peripherals "Common Peripherals".
*
* There are two board versions available on the market with a different pinout
* of the ADC channels and the SPI interface. Which version is used is
* determined by activating a pseudo module for the corresponding version:
*
* - v1.0.0, module `esp32c3_wemos_mini_v1_0_0`
* - v2.1.0, module `esp32c3_wemos_mini_v2_1_0` (default)
*
* To specify which board version is used, simply add the variable
* definition `USEMODULE=...` to the make command line, for example:
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
* USEMODULE=esp32c3_wemos_mini_v1_0_0 BOARD=esp32c3-wemos-min make ...
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
* If the board version is not specified, version v2.1.0 is used by default.
*
* @note
* Most definitions can be overridden by an \ref esp32_application_specific_configurations
* "application-specific board configuration" if necessary.
*
* @file
* @author Gunar Schorcht <gunar@schorcht.net>
*/
#ifndef PERIPH_CONF_H
#define PERIPH_CONF_H
#include <stdint.h>
#ifdef __cplusplus
extern "C" {
#endif
/**
* @name ADC and DAC channel configuration
* @{
*/
/**
* @brief Declaration of GPIOs that can be used as ADC channels
*
* For generic boards, all ADC pins that have broken out are declared as ADC
* channels.
*
* @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
#define ADC_GPIOS { GPIO0, GPIO1, GPIO2, GPIO3, GPIO4, GPIO5 }
#endif
/** @} */
/**
* @name I2C configuration
*
* For generic boards, only one I2C interface I2C_DEV(0) is defined.
*
* The GPIOs listed in the configuration are only initialized as I2C signals
* when module `periph_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 GPIO10 /**< SCL signal of I2C_DEV(0) */
#endif
#ifndef I2C0_SDA
#define I2C0_SDA GPIO8 /**< SDA signal of I2C_DEV(0) */
#endif
/** @} */
/**
* @name PWM channel configuration
*
* For generic boards, two PWM devices are configured. These devices
* contain all GPIOs that are not defined as I2C, SPI or UART for this board.
* Generally, all outputs pins could be used as PWM channels.
*
* @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.
*
* @{
*/
/**
* @brief Declaration of the channels for device PWM_DEV(0),
* at maximum PWM_CHANNEL_NUM_DEV_MAX.
*/
#ifndef PWM0_GPIOS
#ifdef MODULE_ESP32C3_WEMOS_MINI_V1_0_0
#define PWM0_GPIOS { GPIO1, GPIO6, GPIO7 }
#else /* MODULE_ESP32C3_WEMOS_MINI_V2_1_0 */
#define PWM0_GPIOS { GPIO2, GPIO6 }
#endif
#endif
/** @} */
/**
* @name SPI configuration
*
* @note
* - For compatibility with [Wemos D1 mini shields]
* (https://www.wemos.cc/en/latest/d1_mini_shield/index.html), FSPI signals
* do not use direct I/O (IOMUX pin functions) but are routed through the
* GPIO matrix as required for D1 mini shields. This limits the SPI clock
* speed to 26 MHz instead of 80 MHz SPI clock speed.
* - The GPIOs listed in the configuration are not initialized as SPI
* signals until 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.
*
* @{
*/
#ifdef MODULE_ESP32C3_WEMOS_MINI_V1_0_0
#ifndef SPI0_CTRL
#define SPI0_CTRL FSPI /**< FSPI is used as SPI_DEV(0) */
#endif
#ifndef SPI0_SCK
#define SPI0_SCK GPIO2 /**< FSPI SCK signal routed to GPIO2 in GPIO matrix */
#endif
#ifndef SPI0_MISO
#define SPI0_MISO GPIO3 /**< FSPI SCK signal routed to GPIO3 in GPIO matrix */
#endif
#ifndef SPI0_MOSI
#define SPI0_MOSI GPIO4 /**< FSPI SCK signal routed to GPIO4 in GPIO matrix */
#endif
#ifndef SPI0_CS0
#define SPI0_CS0 GPIO5 /**< CS pin controlled in software */
#endif
#else /* MODULE_ESP32C3_WEMOS_MINI_V2_1_0 */
#ifndef SPI0_CTRL
#define SPI0_CTRL FSPI /**< FSPI is used as SPI_DEV(0) */
#endif
#ifndef SPI0_SCK
#define SPI0_SCK GPIO1 /**< FSPI SCK signal routed to GPIO2 in GPIO matrix */
#endif
#ifndef SPI0_MISO
#define SPI0_MISO GPIO0 /**< FSPI SCK signal routed to GPIO3 in GPIO matrix */
#endif
#ifndef SPI0_MOSI
#define SPI0_MOSI GPIO4 /**< FSPI SCK signal routed to GPIO4 in GPIO matrix */
#endif
#ifndef SPI0_CS0
#define SPI0_CS0 GPIO5 /**< CS pin controlled in software */
#endif
#endif
/** @} */
/**
* @name UART configuration
*
* ESP32-C3 provides 2 UART interfaces at maximum:
*
* UART_DEV(0) uses fixed standard configuration.<br>
* UART_DEV(1) is not used.<br>
*
* @{
*/
#define UART0_TXD GPIO21 /**< direct I/O pin for UART_DEV(0) TxD, can't be changed */
#define UART0_RXD GPIO20 /**< direct I/O pin for UART_DEV(0) RxD, can't be changed */
/** @} */
#ifdef __cplusplus
} /* end extern "C" */
#endif
/* include common peripheral definitions as last step */
#include "periph_conf_common.h"
#endif /* PERIPH_CONF_H */
/** @} */