1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/boards/esp8266-olimex-mod/doc.txt
2021-10-15 02:50:21 +02:00

101 lines
4.1 KiB
Plaintext

/**
@defgroup boards_esp8266_olimex-mod Olimex MOD-WIFI-ESP8266-DEV
@ingroup boards_esp8266
@brief Support for the Olimex MOD-WIFI-ESP8266-DEV board.
## Overview
Olimex MOD-WIFI-ESP8266-DEV is a tiny development board that
is available as open-source hardware at
[GitHub](https://github.com/OLIMEX/ESP8266/tree/master/HARDWARE/MOD-WIFI-ESP8266-DEV).
It uses Espressif's ESP8266EX SoC and was originally designed to add
WiFi capabilities to existing boards.
Olimex MOD-WIFI-ESP8266-DEV belongs to the class of general purpose
boards where all ESP8266EX pins are broken out for easier access. The
board can either be soldered directly to a PCB or it can be used with
a breadboard.
@image html "https://gitlab.com/gschorcht/RIOT.wiki-Images/raw/master/esp8266/Olimex-MOD-DEV.png" "Olimex MOD-WIFI-ESP8266-DEV"
\n
The board provides some pads for an UEXT interface. UEXT interface
(introduced by Olimex) can be used to connect different peripherals
to the board. This UEXT interface comprises the 3 serial interfaces
UART, SPI and I2C. For more information about UEXT, see
[UEXT](https://www.olimex.com/Products/Modules/UEXT).
Together with the Olimex ESP8266-EVB evaluation board, a development
platform for IoT devices is available.
@image html "https://www.olimex.com/Products/IoT/ESP8266-EVB/images/ESP8266-EVB.jpg" "Olimex ESP8266-EVB"
## Hardware
### MCU
Most features of the board are provided by the ESP8266EX SoC.
<center>
MCU | ESP8266EX
------------|----------------------------
Family | Tensilica Xtensa LX106
Vendor | Espressif
RAM | 80 kByte
Flash | 2 MByte
Frequency | 80 / 160 MHz
FPU | no
Timers | 1 x 32 bit
ADCs | 1 x 10 bit (1 channel)
LEDs | 1 x GPIO1
I2Cs | 2 (software implementation)
SPIs | 1
UARTs | 1 (console)
WiFi | built in
Vcc | 2.5 - 3.6 V
Datasheet | [Datasheet](https://www.espressif.com/sites/default/files/documentation/0a-esp8266ex_datasheet_en.pdf)
Technical Reference | [Technical Reference](https://www.espressif.com/sites/default/files/documentation/esp8266-technical_reference_en.pdf)
Board Schematic | [Board Schematic](https://github.com/OLIMEX/ESP8266/blob/master/HARDWARE/MOD-WIFI-ESP8266-DEV/MOD-WiFi-ESP8266-DEV%20revision%20B1/MOD-WiFi-ESP8266-DEV_Rev_B1.pdf)
</center>
@note For detailed information about ESP8266, see \ref esp8266_riot.
### RIOT Pin Mapping
Olimex MOD-WIFI-ESP8266-DEV has 22 pin holes that can be soldered to PCB
or used with a breadboard. The following figure shows the mapping of these
pin holes to RIOT pins.
@image html "https://gitlab.com/gschorcht/RIOT.wiki-Images/raw/master/esp8266/Olimex-MOD-DEV_pins.png" "Olimex MOD-WIFI-ESP8266-DEV pin mapping"
\n
Since GPIOs 6, 7, 8, and 11 are used for flash memory, they cannot be used
for other purposes. Furthermore, when flash mode `qout` or `qio` is used for
flash memory, GPIOs 9 and 10 are used for flash memory additionally and cannot
be used for other purposes, see section Flash Modes in \ref esp8266_riot.
## Flashing the Device
To flash the RIOT image, the device must be connected to the host computer
through an FTDI USB to Serial adapter/cable connected to the device's
UART interface, GPIO1 (TxD) and GPIO3 (RxD) ,
@note Please make sure the FTDI USB to Serial adapter/cable uses 3.3 V.
Once the device is connected to the host computer, it must be booted into
UART mode where the firmware can be downloaded via the UART interface. For
this purpose, GPIO15 (MTD0) and GPIO0 must be pulled down and GPIO2 must
be pulled up while the device is restarted using the RSTB pin. Since
GPIO15 (MTDO) is pulled down and GPIO0 as well as GPIO2 are pulled up
by solder bridges, only GPIO0 needs to be pulled down while the device
is being reset with the RSTB pin.
To flash the RIOT image just type:
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
make flash BOARD=esp8266-olimex-mod ...
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
For detailed information about ESP8266 as well as configuring and compiling
RIOT for ESP8266 boards, see \ref esp8266_riot.
*/