/** @defgroup boards_esp8266_sparkfun-thing SparkFun ESP8266 Thing @ingroup boards_esp8266 @brief Support for the SparkFun ESP8266 Thing modules. ## Overview The [SparkFun ESP8266 Thing](https://www.sparkfun.com/products/13231) and [SparkFun ESP8266 Thing DEV](https://www.sparkfun.com/products/13711) are low-cost and easy to use breakout and development boards for the ESP8266. Both SparkFun ESP8266 Thing boards are relatively simple boards. The pins are simply broken out to two parallel, breadboard-compatible rows. @image html "https://gitlab.com/gschorcht/RIOT.wiki-Images/raw/master/esp8266/Sparkfun_Thing_x.png" "SparkFun ESP8266 Thing (left) / SparkFun ESP8266 Thing DEV (right)" ## Hardware ### MCU Most features of the board are provided by the ESP8266EX SoC.
MCU | ESP8266EX ------------|---------------------------- Family | Tensilica Xtensa LX106 Vendor | Espressif RAM | 80 kByte Flash | 512 kByte 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 | [ESP8266 Thing](https://cdn.sparkfun.com/datasheets/Wireless/WiFi/SparkFun_ESP8266_Thing.pdf)\n [ESP8266 Thing Dev](https://cdn.sparkfun.com/datasheets/Wireless/WiFi/ESP8266-Thing-Dev-v10.pdf)
### Board Versions Although the board definition works with both boards, it's important to know that they differ slightly in some features:
Feature | ESP8266 Thing | ESP8266 Thing Dev -------------------------------|---------------|------------------ USB to Serial adapter on-board | no | yes I2C pull-up resistors on-board | yes (jumpable)| no [1] Programming interface | FTDI USB to Serial adapter | USB Reset/Flash/Boot logic | FTDI | USB Battery connector | yes | no (can be retrofitted) LiPo Charger on-board | yes | no LED (GPIO5) | high active | low active [2] GPIO15 broken out | no | yes CHIP_EN broken out | yes | no
[1] Although the SparkFun ESP8266 Thing Dev has no on-board I2C pull-up resistors, the I2C interface can be used because the ESP8266 SoC has built-in pull-up resistors that are activated by the I2C peripheral driver. [2] The board configuration defines high-active LEDs. If the SparkFun ESP8266 Thing Dev is used with this board configuration, the LED outputs must be inverted by the application. ### RIOT Pin Mapping The following figures show the mapping of these pin holes to RIOT pins. @image html "https://gitlab.com/gschorcht/RIOT.wiki-Images/raw/master/esp8266/Sparkfun_Thing_pinout.png" "SparkFun Thin Pinout" \n @image html "https://gitlab.com/gschorcht/RIOT.wiki-Images/raw/master/esp8266/Sparkfun_Thing_Dev_pinout.png" "SparkFun Thin Dev Pinout" \n Flash SPI pins including GPIO9 and GPIO10 are not broken out. The SparkFun Thing board has solder pads for these pins at the bottom layer. ## Flashing the Device To flash the RIOT image, the device has to be connected to the host computer. Since the SparkFun Thing Dev board has an USB to Serial adapter on board, this can done directly using the Micro USB. SparkFun Thin board has to be connected to the host computer using the FTDI interface and a FTDI USB to Serial adapter/cable. For more information on how to program the SparkFun Thing board, please refer the [ESP8266 Thing Hookup Guide](https://learn.sparkfun.com/tutorials/esp8266-thing-hookup-guide/programming-the-thing). @note Please make sure the FTDI USB to Serial adapter/cable uses 3.3 V. Both boards have a reset/flash/boot logic on-board so that flashing is quite simple. To flash the RIOT image just type: ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ make flash BOARD=esp8266-sparkfun-thing ... ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ For detailed information about ESP8266 as well as configuring and compiling RIOT for ESP8266 boards, see \ref esp8266_riot. */