环境准备:
- 系统Ubuntu 20.0.4.6 LTS
Ubuntu安装教程: 第一章 Ubuntu Server版本选择及安装-CSDN博客
软件源地址在安装系统的时候已直接换成了清华源,登陆系统进行必备软件安装
软件安装:
- Git安装:sudo apt-get install git
git is already the newest version (1:2.25.1-1ubuntu3.11).
显示已经是最新版本,无需更新
- python3.9安装:sudo apt install python3.9
提示:Do you want to continue? [Y/n] 输入Y回车
- GCC安装:sudo apt install build-essential
build-essential
它包含 GCC 和其他各种编译器提示:Do you want to continue? [Y/n] 输入Y回车
- cmake安装:sudo apt-get install cmake
提示:Do you want to continue? [Y/n] 输入Y回车
- python3.8-venv安装:sudo apt install python3.8-venv
提示:Do you want to continue? [Y/n] 输入Y回车
Git克隆ESP-IDF
- 从micropython源码关于esp32项目下的文件说明获得最新版本固件需要什么版本的ESP-IDF
地址:https://github.com/micropython/micropython/tree/master/ports/esp32
根据官方源码给出的版本,我们选择v5.0.4版本的.ESP-IDF
克隆命令:git clone -b v5.0.4 --recursive https://github.com/espressif/esp-idf.git
克隆结束后,因为网速的问题,有时候有一些文件会克隆失败。如图所示:
这个时候我们进入克隆的ESP-IDF目录下
运行命令:git submodule update --init --recursive
同步仓库中的文件,直到我们运行命令后,无任何提示则克隆完整。如图所示:
- 克隆官方最新固件源码
克隆命令: git clone --recursive
https://github.com/micropython/micropython.git
同样克隆完成后,进入micropython文件夹里
运行命令:git submodule update --init --recursive
同步仓库中的文件,直到我们运行命令后,无任何提示则克隆完整。如图所示:
编译环境配置:
- 进入ESP-IDF目录下
运行命令:./install.sh
成功安装,如图所示:
运行命令:source export.sh
成功运行,如图所示:
进入micropython目录下
构建MicroPython交叉编译器
运行命令:
make -C mpy-cross
构建成功后,如图所示:
- 进入micropython/ports/esp32目录下
同步子模块
运行命令:make submodules
成功后,如图所示:
- 编译固件
运行命令:make
成功编译固件,如图所示:
- 编译成功后,固件生成的位置:
micropython/ports/esp32/build-ESP32_GENERIC/firmware.bin
- 刷入固件后显示
- 官方默认固件为4M固件,修改16M固件
配置文件位置:micropython/ports/esp32/boards/sdkconfig.base
打开文件后,找到
# For cmake build
CONFIG_ESPTOOLPY_FLASHSIZE_4MB=y
CONFIG_PARTITION_TABLE_CUSTOM=y
CONFIG_PARTITION_TABLE_CUSTOM_FILENAME="partitions-4MiB.csv"注释掉原来的代码,添加新的代码:
CONFIG_ESPTOOLPY_FLASHSIZE_16MB=y
CONFIG_PARTITION_TABLE_CUSTOM=y
CONFIG_PARTITION_TABLE_CUSTOM_FILENAME="partitions-16MiB.csv"
添加后如图所示:
保存后,在micropython/ports/esp32目录下
执行命令:make clean
再重新编译:make
这样就得到了一个16M的官方最新固件,如图所示:
- 如果想编译ESP32-S3版本的固件
编译的时候带上命令参数即可
命令:make BOARD=GENERIC_C3
固件分享:
16M固件