Dieser Schritt wurde bereits gemacht und muss nicht wiederholt werden. Sollte Ihr ESP8266 einmal aus unerklärlichen Gründen nicht mehr funktionieren, so könnte das neue Aufspielen (flashen) der Firmware allenfalls helfen.
This article describes how to generate and flash the MicroPython firmware for the ESP8266 board. The steps are similar for other boards, but the firmware must be generated for the specific board.
This manual is based on the 👉 Compiling MicroPython for esp8266 article.
The operating system used for this task is Ubuntu 22 on WSL.
Create the Micropython folder and inside this folder the esp8266 folder
mkdir Micropython
cd Micropython
mkdir esp8266
cd esp8266
The MicroPython source code is available at 👉 Github Micropython. Instructions to build the firmware for the ESP8266 are available at 👉 MicroPython esp8266.
Clone the repository
git clone https://github.com/micropython/micropython
Download the cross compiler, as described in 👉 Cross compiler
As indicated in the link above, download the source of the cross compiler always from the folder esp8266
git clone --recursive https://github.com/pfalcon/esp-open-sdk
Install the prerequisites for building
sudo apt-get install make unrar-free autoconf automake libtool gcc g++ gperf flex bison texinfo gawk ncurses-dev libexpat-dev python-dev python python3-serial sed git unzip bash help2man wget bzip2 libtool-bin
Now we must download some tarballs which are not available anymore through the mirrors used by the compiler
# some tarballs (binaries) are not available anymore on the preconfigured mirror - download them manually
cd crosstool-NG/.build/tarballs/
wget https://libisl.sourceforge.io/isl-0.14.tar.gz
wget https://github.com/libexpat/libexpat/releases/download/R_2_1_0/expat-2.1.0.tar.gz
# compiler needs Python v2.7 - new ubuntu versions have Python v3 as default
mkdir /tmp/tmpbin && ln -s /usr/bin/python2.7 /tmp/tmpbin/python && export PATH=/tmp/tmpbin:${PATH}
# ensure serial module is found - get current version from https://pypi.org/project/pyserial/#files
cd /tmp/tmpbin
wget https://files.pythonhosted.org/packages/1e/7d/ae3f0a63f41e4d2f6cb66a5b57197850f919f59e558159a4dd3a818f5082/pyserial-3.5.tar.gz
tar -xzf pyserial-3.5.tar.gz
cd pyserial-3.5
sudo /usr/bin/python2.7 setup.py install
Proceed to the build of the cross compiler with the following commands
cd esp-open-sdk
make STANDALONE=y |& tee make0.log
At the end of the build add the binary folder of the cross compiler to the PATH envinronment variable
export PATH=~/Micropython/esp8266/esp-open-sdk/xtensa-lx106-elf/bin:$PATH
Go into the micropython folder available under ~/Micropython/esp8266
cd ~/Micropython/esp8266/micropython
Run
git submodule update --init
to add external dependencies.
Next step is the MicroPython cross compiler build
make -C mpy-cross
Finally we can build the ESP8266 firmware with the following commands
cd ports/esp8266
make axtls
make
Add modules
Now you can place all the modules you want to add to the firmware in the Micropython\esp8266\micropython\ports\esp8266 folder.
AHT21 Sensor Module
https://github.com/lebalz/ofi-blog/blob/main/docs/EF-IOT-Workshop/05-micropython/modules/aht.py
ENS160 Sensor Module
https://github.com/lebalz/ofi-blog/blob/main/docs/EF-IOT-Workshop/05-micropython/modules/ens.py
PiicoDev_Unified Module
https://github.com/lebalz/ofi-blog/blob/main/docs/EF-IOT-Workshop/05-micropython/modules/PiicoDev_Unified.py
then recompile the firmware from the folder Micropython\esp8266\micropython\ports\esp8266 with the command
make clean
make
Flash the firmware
The firmware is generated under ports/esp8266/build-GENERIC folder with the name firmware-combined.bin.
Proceed to flash the firmware...
WSL / Windows
Sadly, WSL 2 does not support yet USB devices by default. Becaus of that we use PowerShell to flash the firmware.
Open the Folder containing \Micropython\esp8266\micropython\ports\esp8266 in PowerShell (or only the firmware you downloaded above). Make sure you have python and esptools installed:
pip install esptool
When you encounter problems with flashing or connecting to esp8266, try using this usb serial firmware: https://sparks.gogo.co.nz/ch340.html
esptool --port COMXX erase_flash
where COMXX is repalced with the actual serial port to which we connect the ESP8266 board.
In my case, the command looked like this
esptool --port COM3 erase_flash
And then upload the firmware with the command
esptool --port COM3 --baud 460800 write_flash --flash_size=detect 0 .\build-GENERIC\firmware-combined.bin
UNIX
esptool.py --port /dev/ttyXXX erase_flash
where /dev/ttyXXX is repalced with the actual serial port to which we connect the ESP8266 board.
In our case, the firmware upload was successful with the command
make PORT=/dev/ttyUSB0 deploy
It is also possible to load the firmware_combined.bin image with the command
esptool.py --port /dev/ttyUSBX --baud 460800 write_flash --flash_size=detect 0 firmware-combined.bin
⭐ Building Micro Python