micropython/esp8266
Paul Sokolovsky 2e75a17bab esp8266: Fix issue when current repl line was garbage-collected.
Reference it from root pointers section.
2016-03-30 18:13:03 +03:00
..
scripts
tests esp8266/tests: Add neopixel.py test. 2016-03-26 10:55:29 +02:00
Makefile esp8266: Let esp8266 "os" messages go to standard (REPL) UART. 2016-03-29 21:10:10 +03:00
README.md esp8266/README: Update for the current status of the port. 2016-03-27 16:10:58 +03:00
eagle.rom.addr.v6.ld
esp8266.ld esp8266/esp8266.ld: Put FatFs to FlashROM. 2016-03-27 17:15:25 +03:00
esp_mphal.c esp8266/esp_mphal: Add support for debug UART-only output. 2016-03-29 11:48:43 +03:00
esp_mphal.h esp8266: Support synchronous wifi scanning. 2016-03-30 11:35:03 +03:00
espneopixel.c esp8266: Add esp.neopixel_write function to bit-bang WS2812 data. 2016-03-26 10:55:21 +02:00
espneopixel.h esp8266: Add esp.neopixel_write function to bit-bang WS2812 data. 2016-03-26 10:55:21 +02:00
esppwm.c esp8266/esppwm.c: Fix IRQ handler prototype. 2016-03-26 00:34:28 +02:00
esppwm.h esp8266: Add PWM support. 2016-03-26 00:32:37 +02:00
ets_alt_task.c
ets_alt_task.h
etshal.h esp8266: Implement os.urandom function. 2016-03-29 10:29:57 +03:00
fatfs_port.c esp8266: Enable FatFs support. 2016-03-27 17:13:47 +03:00
gccollect.c
gccollect.h
gchelper.s
lexerstr32.c
main.c esp8266: Reduce heap size for now to avoid random segfaults on WiFi connect. 2016-03-29 21:14:41 +03:00
makeimg.py
modesp.c esp8266/modesp: flash_read(): Accept buffer to read to as a second argument. 2016-03-27 15:34:35 +03:00
modmachine.c esp8266: Link ADC class into machine module. 2016-03-26 00:41:37 +02:00
modnetwork.c esp8266: Support synchronous wifi scanning. 2016-03-30 11:35:03 +03:00
modonewire.c
modpyb.c
modpyb.h esp8266: Add PWM support. 2016-03-26 00:32:37 +02:00
modpybadc.c
modpybi2c.c
modpybpin.c
modpybpwm.c esp8266: Add PWM support. 2016-03-26 00:32:37 +02:00
modpybrtc.c
modpybrtc.h
modpybspi.c
moduos.c esp8266: Enable uos.dupterm() method. 2016-03-29 11:41:23 +03:00
modutime.c
mpconfigport.h esp8266: Fix issue when current repl line was garbage-collected. 2016-03-30 18:13:03 +03:00
qstrdefsport.h esp8266: Add esp.neopixel_write function to bit-bang WS2812 data. 2016-03-26 10:55:21 +02:00
strtoll.c
uart.c esp8266: Let esp8266 "os" messages go to standard (REPL) UART. 2016-03-29 21:10:10 +03:00
uart.h
uart_register.h
user_config.h
utils.c
utils.h

README.md

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.
  • Basic WiFi support.
  • Sockets using modlwip.
  • GPIO and bit-banging I2C, SPI support.
  • 1-Wire and WS2812 (aka Neopixel) protocols support.

On the TODO list:

  • Full wifi support.
  • Internal filesystem using the flash.
  • ...

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.

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

This should produce binary images in the build/ subdirectory. To flash them 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, 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 images that are built are:

  • firmware.elf-0x00000.bin: to be flashed at 0x00000
  • firmware.elf-0x10000.bin: to be flashed at 0x10000

There is also a combined image, made up of the above 2 binary files with the appropriate padding:

  • firmware-combined.bin: to be flashed at 0x00000