circuitpython/esp8266
Paul Sokolovsky 2123ced3f4 esp8266/modesp: Add esf_free_bufs() debugging function.
Return number of free inernal WiFi buffers.
2016-05-03 00:26:22 +03:00
..
scripts esp8266/scripts/webrepl_setup: Reject too short passwords. 2016-05-02 18:48:32 +03:00
axtls_helpers.c esp8266/axtls_helpers: Helper/wrapper functions for axTLS. 2016-04-27 14:54:36 +03:00
eagle.rom.addr.v6.ld
esp8266.ld esp8266/esp8266.ld: Put axTLS to FlashROM. 2016-04-27 00:45:09 +03:00
esp_mphal.c esp8266/esp_mphal: Add ets_esf_free_bufs(), etc. functions. 2016-05-03 00:18:14 +03:00
esp_mphal.h esp8266/esp_mphal: Add ets_esf_free_bufs(), etc. functions. 2016-05-03 00:18:14 +03:00
espneopixel.c
espneopixel.h
esponewire.c
esponewire.h
esppwm.c
esppwm.h
ets_alt_task.c esp8266/ets_alt_task: Comment out debug output. 2016-04-03 01:04:01 +03:00
ets_alt_task.h
etshal.h
fatfs_port.c
gccollect.c
gccollect.h
gchelper.s
help.c esp8266/help: Add cheatsheet for basic WiFi configuration. 2016-04-29 00:34:08 +03:00
intr.c
lexerstr32.c
main.c
Makefile esp8266/Makefile: Be sure to pass cross-compiling AR when building axtls. 2016-05-02 01:22:42 +03:00
makeimg.py
modesp.c esp8266/modesp: Add esf_free_bufs() debugging function. 2016-05-03 00:26:22 +03:00
modmachine.c py: Move call_function_*_protected() functions to py/ for reuse. 2016-04-25 19:31:17 +03:00
modnetwork.c esp8266/modnetwork: Remove deprecated wifi_mode(). 2016-05-03 00:09:23 +03:00
modonewire.c
modpyb.c esp8266: Move pyb.info() function to esp module and remove pyb module. 2016-04-28 12:23:55 +01:00
modpyb.h esp8266: Move pyb.info() function to esp module and remove pyb module. 2016-04-28 12:23:55 +01:00
modpybadc.c
modpybpin.c py: Move call_function_*_protected() functions to py/ for reuse. 2016-04-25 19:31:17 +03:00
modpybpwm.c
modpybrtc.c esp8266: Implement basic deep-sleep capabilities. 2016-04-21 11:43:37 +01:00
modpybrtc.h esp8266: Implement basic deep-sleep capabilities. 2016-04-21 11:43:37 +01:00
modpybspi.c esp8266: Change software SPI driver to use general pin HAL. 2016-04-22 10:44:06 +01:00
modpybuart.c esp8266: Implement UART.read functionality. 2016-04-21 15:19:19 +01:00
moduos.c esp8266/moduos: Add dupterm_notify() function. 2016-04-17 18:09:52 +03:00
modutime.c
mpconfigport.h esp8266: Change platform name from ESP8266 to esp8266. 2016-05-02 18:54:46 +01:00
qstrdefsport.h esp8266: Adapt port to use new auto-qstr generation. 2016-04-16 13:20:02 +01:00
README.md esp8266/README: Mention WebREPL. 2016-04-30 23:02:54 +03:00
strtoll.c
uart_register.h
uart.c esp8266/uart: Remove obsolete UART rx buffering code. 2016-04-21 15:27:18 +01:00
uart.h esp8266: Add uart_rx_wait and uart_rx_char functions. 2016-04-21 15:19:00 +01:00
user_config.h esp8266: New port of Micro Python to ESP8266 wifi module. 2014-11-27 20:30:33 +00:00

MicroPython port to ESP8266

This is a highly experimental port of MicroPython for the WiFi modules based on Espressif ESP8266 chip.

WARNING: The port is highly experimental and any APIs are subject to change.

Currently implemented features include:

  • REPL (Python prompt) over UART0.
  • Garbage collector, exceptions.
  • Unicode support.
  • Builtin modules: gc, array, collections, io, struct, sys, esp, network, many more.
  • Arbitrary-precision long integers and 30-bit precision floats.
  • WiFi support.
  • Sockets using modlwip.
  • GPIO and bit-banging I2C, SPI support.
  • 1-Wire and WS2812 (aka Neopixel) protocols support.
  • Internal filesystem using the flash.
  • WebREPL over WiFi from a browser (clients at https://github.com/micropython/webrepl).

Work-in-progress documentation is available at http://docs.micropython.org/en/latest/esp8266/ .

Build instructions

The tool chain required for the build is the OpenSource ESP SDK, which can be found at https://github.com/pfalcon/esp-open-sdk. Clone this repository and run make in its directory to build and install the SDK locally. Make sure to add toolchain bin directory to your PATH. Read esp-open-sdk's README for additional important information on toolchain setup.

Add the external dependencies to the MicroPython repository checkout:

$ git submodule update --init

See the README in the repository root for more information about external dependencies.

Then, to build MicroPython for the ESP8266, just run:

$ cd esp8266
$ make axtls
$ make

This will produce binary images in the build/ subdirectory. If you install MicroPython to your module for the first time, or after installing any other firmware, you should erase flash completely:

esptool.py --port /dev/ttyXXX erase_flash

Erase flash also as a troubleshooting measure, if a module doesn't behave as expected.

To flash MicroPython image to your ESP8266, use:

$ make deploy

This will use the esptool.py script to download the images. You must have your ESP module in the bootloader mode, and connected to a serial port on your PC. The default serial port is /dev/ttyACM0. To specify another, use, eg:

$ make PORT=/dev/ttyUSB0 deploy

The image produced is firmware-combined.bin, to be flashed at 0x00000.

Troubleshooting

While the port is still in alpha, it's known to be generally stable. If you experience strange bootloops, crashes, lockups, here's a list to check against:

  • You didn't erase flash before programming MicroPython firmware.
  • Firmware can be occasionally flashed incorrectly. Just retry. Recent esptool.py versions have --verify option.
  • Power supply you use doesn't provide enough power for ESP8266 or isn't stable enough.
  • A module/flash may be defective (not unheard of for cheap modules).

Please consult dedicated ESP8266 forums/resources for hardware-related problems.