2018-09-05 02:39:50 +02:00
|
|
|
/*
|
|
|
|
* 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_common_esp8266
|
|
|
|
* @brief Configurations of the MCU periphery that are common for all
|
|
|
|
* ESP8266 boards
|
|
|
|
* @file
|
|
|
|
* @author Gunar Schorcht <gunar@schorcht.net>
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef PERIPH_CONF_COMMON_H
|
|
|
|
#define PERIPH_CONF_COMMON_H
|
|
|
|
|
|
|
|
/* include board.h and periph_cpu.h to make them visible in any case */
|
|
|
|
#include "periph_cpu.h"
|
2019-09-05 14:32:59 +02:00
|
|
|
#include "kernel_defines.h"
|
2018-09-05 02:39:50 +02:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef BIT
|
|
|
|
#define BIT(X) (1<<(X))
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name ADC configuration
|
|
|
|
*
|
|
|
|
* ESP8266 provides one ADC pin that is broken out on all boards.
|
|
|
|
* @{
|
|
|
|
*/
|
2019-09-05 14:32:59 +02:00
|
|
|
#define ADC_NUMOF (1) /**< number of ADC channels */
|
2018-09-05 02:39:50 +02:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
|
2019-09-05 14:32:59 +02:00
|
|
|
/**
|
|
|
|
* @name DAC configuration
|
|
|
|
*
|
|
|
|
* ESP8266 provides no DAC.
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define DAC_NUMOF (0) /**< number of DAC channels */
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name I2C configuration
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Static array with configuration for declared I2C devices
|
|
|
|
*/
|
|
|
|
static const i2c_conf_t i2c_config[] = {
|
|
|
|
#if defined(I2C0_SCL) && defined(I2C0_SDA) && defined(I2C0_SPEED)
|
|
|
|
{
|
|
|
|
.speed = I2C0_SPEED,
|
|
|
|
.scl = I2C0_SCL,
|
|
|
|
.sda = I2C0_SDA,
|
|
|
|
},
|
|
|
|
#endif
|
|
|
|
#if defined(I2C1_SCL) && defined(I2C1_SDA) && defined(I2C1_SPEED)
|
|
|
|
{
|
|
|
|
.speed = I2C1_SPEED,
|
|
|
|
.scl = I2C1_SCL,
|
|
|
|
.sda = I2C1_SDA,
|
|
|
|
},
|
|
|
|
#endif
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Number of I2C interfaces
|
|
|
|
*
|
|
|
|
* The number of I2C interfaces is determined automatically from board-specific
|
|
|
|
* peripheral definitions.
|
|
|
|
*
|
|
|
|
* @note I2C_NUMOF definition must not be changed.
|
|
|
|
*/
|
|
|
|
#define I2C_NUMOF ARRAY_SIZE(i2c_config)
|
|
|
|
|
|
|
|
/** @} */
|
|
|
|
|
2018-09-05 02:39:50 +02:00
|
|
|
/**
|
|
|
|
* @name PWM configuration
|
|
|
|
*
|
2019-09-05 14:32:59 +02:00
|
|
|
* The hardware implementation of ESP8266 PWM supports only frequencies as
|
|
|
|
* power of two. Therefore a software implementation of one PWM device
|
|
|
|
* PWM_DEV(0) with up to 8 PWM channels (#PWM_CHANNEL_NUM_MAX) is used. The
|
|
|
|
* GPIOs that can be used as PWM channels are defined by #PWM0_GPIOS in board
|
|
|
|
* definition.
|
2018-09-05 02:39:50 +02:00
|
|
|
*
|
2019-09-05 14:33:24 +02:00
|
|
|
* @note The minimum PWM period that can be realized is 10 us or 100.000 PWM
|
2018-09-05 02:39:50 +02:00
|
|
|
* clock cycles per second. Therefore, the product of frequency and resolution
|
|
|
|
* should not be greater than 100.000. Otherwise the frequency is scaled down
|
|
|
|
* automatically.
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
2019-09-05 14:32:59 +02:00
|
|
|
#if defined(PWM0_GPIOS) || defined(DOXYGEN)
|
2018-09-05 02:39:50 +02:00
|
|
|
/**
|
2019-09-05 14:32:59 +02:00
|
|
|
* @brief Static array of GPIOs that can be used as channels of PWM_DEV(0)
|
2018-09-05 02:39:50 +02:00
|
|
|
*/
|
2019-09-05 14:32:59 +02:00
|
|
|
static const gpio_t pwm0_channels[] = PWM0_GPIOS;
|
2018-09-05 02:39:50 +02:00
|
|
|
|
|
|
|
/**
|
2019-09-05 14:32:59 +02:00
|
|
|
* @brief Number of PWM devices
|
2018-09-05 02:39:50 +02:00
|
|
|
*
|
2019-09-05 14:32:59 +02:00
|
|
|
* The number of PWM devices is determined from the #PWM0_GPIOS definition.
|
|
|
|
*
|
|
|
|
* @note #PWM_NUMOF definition must not be changed.
|
2018-09-05 02:39:50 +02:00
|
|
|
*/
|
2019-09-05 14:32:59 +02:00
|
|
|
#define PWM_NUMOF (1) /**< Number of PWM devices */
|
2018-09-05 02:39:50 +02:00
|
|
|
|
2019-09-05 14:32:59 +02:00
|
|
|
#endif /* defined(PWM0_GPIOS) || defined(DOXYGEN) */
|
2018-09-05 02:39:50 +02:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
2019-09-05 14:32:59 +02:00
|
|
|
* @name SPI configuration
|
|
|
|
*
|
|
|
|
* ESP8266 has two SPI controllers:
|
2018-09-05 02:39:50 +02:00
|
|
|
*
|
2019-09-05 14:32:59 +02:00
|
|
|
* - _CSPI_ for caching and accessing the flash memory<br>
|
|
|
|
* - _HSPI_ for peripherals
|
2018-09-05 02:39:50 +02:00
|
|
|
*
|
2019-09-05 14:32:59 +02:00
|
|
|
* Thus, _HSPI_ is the only SPI interface that is available for peripherals.
|
|
|
|
* It is exposed as RIOT's SPI_DEV(0). Furthermore, the pin configuration of
|
|
|
|
* the _HSPI_ interface is fixed as shown in following table.
|
2018-09-05 02:39:50 +02:00
|
|
|
*
|
2019-09-05 14:32:59 +02:00
|
|
|
* Signal | Pin
|
|
|
|
* -----------|-------
|
|
|
|
* #SPI0_MISO | GPIO12
|
|
|
|
* #SPI0_MOSI | GPIO13
|
|
|
|
* #SPI0_SCK | GPIO14
|
|
|
|
* #SPI0_CS0 | GPIOn with n = 0, 2, 4, 5, 15, 16 (additionally 9, 10 in DOUT flash mode)
|
2018-09-05 02:39:50 +02:00
|
|
|
*
|
2019-09-05 14:32:59 +02:00
|
|
|
* The only pin definition that can be overridden by an application-specific
|
|
|
|
* board configuration is the CS signal defined by #SPI0_CS0.
|
2018-09-05 02:39:50 +02:00
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
2019-09-05 14:32:59 +02:00
|
|
|
#define SPI0_DEV SPI_DEV(0) /**< HSPI / SPI_DEV(0) device */
|
|
|
|
#define SPI0_CTRL HSPI /**< HSPI / SPI_DEV(0) controller */
|
|
|
|
#define SPI0_MISO GPIO12 /**< HSPI / SPI_DEV(0) MISO pin */
|
|
|
|
#define SPI0_MOSI GPIO13 /**< HSPI / SPI_DEV(0) MOSI pin */
|
|
|
|
#define SPI0_SCK GPIO14 /**< HSPI / SPI_DEV(0) SCK pin */
|
2018-09-05 02:39:50 +02:00
|
|
|
|
2019-09-05 14:32:59 +02:00
|
|
|
#ifndef SPI0_CS0
|
|
|
|
#define SPI0_CS0 GPIO15 /**< HSPI / SPI_DEV(0) CS default pin, only used when cs
|
|
|
|
parameter in spi_acquire is #GPIO_UNDEF */
|
|
|
|
#endif
|
2018-09-05 02:39:50 +02:00
|
|
|
|
2019-09-05 14:32:59 +02:00
|
|
|
/**
|
|
|
|
* @brief Static array with configuration for declared SPI devices
|
|
|
|
*/
|
|
|
|
static const spi_conf_t spi_config[] = {
|
|
|
|
#ifdef SPI0_CTRL
|
|
|
|
{
|
|
|
|
.ctrl = SPI0_CTRL,
|
|
|
|
.sck = SPI0_SCK,
|
|
|
|
.mosi = SPI0_MOSI,
|
|
|
|
.miso = SPI0_MISO,
|
|
|
|
.cs = SPI0_CS0,
|
|
|
|
},
|
2018-09-05 02:39:50 +02:00
|
|
|
#endif
|
2019-09-05 14:32:59 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Number of SPI interfaces
|
|
|
|
*
|
|
|
|
* The number of SPI interfaces is determined from board-specific peripheral
|
|
|
|
* definitions of SPIn_*.
|
|
|
|
*
|
|
|
|
* @note SPI_NUMOF definition must not be changed.
|
|
|
|
*/
|
|
|
|
#define SPI_NUMOF ARRAY_SIZE(spi_config)
|
|
|
|
|
2018-09-05 02:39:50 +02:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Timer configuration
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#if defined(MODULE_ESP_SW_TIMER)
|
|
|
|
|
|
|
|
/* software timer */
|
|
|
|
#define TIMER_NUMOF (1U) /**< number of timer devices */
|
2020-06-23 19:21:54 +02:00
|
|
|
#define TIMER_CHANNEL_NUMOF (10U) /**< number of channels per timer device */
|
2018-09-05 02:39:50 +02:00
|
|
|
|
|
|
|
#else /* MODULE_ESP_SW_TIMER */
|
|
|
|
|
|
|
|
/* hardware timer */
|
|
|
|
#define TIMER_NUMOF (1U) /**< number of timer devices */
|
2020-06-23 19:21:54 +02:00
|
|
|
#define TIMER_CHANNEL_NUMOF (1U) /**< number of channels per timer device */
|
2018-09-05 02:39:50 +02:00
|
|
|
|
|
|
|
#endif /* MODULE_ESP_SW_TIMER */
|
|
|
|
/** @} */
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name UART configuration
|
|
|
|
*
|
|
|
|
* All ESP8266 boards have exactly one UART device with fixed pin mapping.
|
|
|
|
* This UART device is used for flashing and as a console interface.
|
|
|
|
* Therefore, the number of UART devices is fixed and can not be overridden.
|
|
|
|
* Used pins are determined by the MCU implementation and are defined here
|
|
|
|
* only for documentation reasons.
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*/
|
2019-09-05 14:32:59 +02:00
|
|
|
|
2018-09-05 02:39:50 +02:00
|
|
|
#define UART0_TXD GPIO1 /**< TxD pin of UART_DEV(0) */
|
|
|
|
#define UART0_RXD GPIO3 /**< RxD pin of UART_DEV(0) */
|
2019-09-05 14:32:59 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Static array with configuration for declared UART devices
|
|
|
|
*/
|
|
|
|
static const uart_conf_t uart_config[] = {
|
|
|
|
{
|
|
|
|
.txd = UART0_TXD,
|
|
|
|
.rxd = UART0_RXD,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Number of UART interfaces
|
|
|
|
*
|
|
|
|
* The number of UART interfaces is determined from board-specific peripheral
|
|
|
|
* definitions of UARTn_*.
|
|
|
|
*
|
|
|
|
* @note UART_NUMOF definition must not be changed.
|
|
|
|
*/
|
2020-02-08 17:30:12 +01:00
|
|
|
#define UART_NUMOF ARRAY_SIZE(uart_config)
|
2018-09-05 02:39:50 +02:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
} /* end extern "C" */
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* PERIPH_CONF_COMMON_H */
|
|
|
|
/** @} */
|