完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
1. 功能概述
esptool.py 是一个基于 python 的开源,用于和 ESP8266 & ESP32 产品的 ROM bootloader 进行通信的工具,不依赖于任何平台。当前维护 esptool 的总负责人是 Angus。 esptool 已经成为了 python 的一个官方模块,适用于 python 2.6 或 python 3.4 及以上版本。它可以通过 pip 直接安装,命令为pip install esptool。安装完成后,esptool.py 会出现在默认 python 可执行路径中,可在 python 命令行中直接 import。 2. 使用指导 2.1. HELP 指令 在 esptool.py 后面跟参数 -h,可以查看 esptool 可以使用的所有功能。命令得到的返回如下: 要查看某特定指令后跟的参数,也可以在指令后跟 -h 查看。 2.2. 通用选项 使用 esptool.py 需要添加三个通用选项:
2.3.1. ELF 转成二进制文件 elf2image 命令可以将 ELF 文件转变成可以下载的二进制文件。命令示例:esptool.py --chip esp8266 elf2image my_app.elf。 该指令不需要与串口连接。该指令可以跟 --flash_freq 和 --flash_mode 参数,将此配置参数写入固件头中。这样就可以将生成的固件直接下载到芯片中。不过 write_flash 指令可以改变固件中的配置参数。
由 elf2image 和 make image 生成的二进制文件可以通过串口 write_flash 指令写到芯片中。指令示例如下:esptool.py --port com2 write_flash 0x1000 my_app-0x01000.bin。 该命令也可以下载多个固件,指令示例如下:esptool.py --port com2 write_flash 0x00000 my_app.elf-0x00000.bin 0x40000 my_app.elf-0x40000.bin。 参数顺序依次是 chip (只有一个芯片连接时可以省略),port,随后是各个固件的起始地址与名称。当生成 ESP8266 一级 boot 固件时,由 elf2image 指令生成的固件名称会包含固件起始地址。对于其他类型的固件而言,从 SDK 中找到固件下载地址。 同时,还可以添加 flash mode 和 flash size 作为参数,用于修改默认 flash 启动配置。指令示例如下:esptool.py --port com2 write_flash --flash_mode qio --flash_size 32m 0x0 bootloader.bin 0x1000 my_app.bin。 串口传输数据的性能默认通过压缩提升。如果不需要压缩数据,通过 -u/--no-compress 来配置。 2.3.3. 确认 flash 写 flash 后会通过验证数据的 MD5 值来确认下载,并不需要人工再次确认。如果一定要验证,则通过 verify_flash 指令来完成。指令示例如下:esptool.py --port com2 verify_flash 0x40000 my_app.elf-0x40000.bin 注:如果需要验证的是 boot 固件,那通过 --flash_mode、--flash_size 和 --flash_freq 配置的参数均需要在确认 flash 命令后面给出,否则确认会失败。2.3.4. 手动生成固件 固件可以通过几个二进制段来合成。指令示例如下:esptool.py --chip esp8266 make_image -f app.text.bin -a 0x40100000 -f app.data.bin -a 0x3ffe8000 -f app.rodata.bin -a 0x3ffe8c00 app.flash.bin。 该指令无需串口连接,目前只适用于 ESP8266。 2.3.5. DUMP MEM 命令 dump_mem 指令会将芯片内存中的一片区域保存出来。示例指令展示了从 ESP8266 ROM 保存出 64KB 数据:esptool.py --port com2 dump_mem 0x40000000 65536 iram0.bin。 2.3.6. 读 MAC 地址命令 该指令经常被用来验证是否能与芯片进行通信,在 RMA 阶段很常见。通常客户返回硬件问题时,会先读取 MAC 地址确保芯片内部正常。指令示例如下:esptool.py --port com2 read_mac。 2.3.7. 读 flash 信息命令 读 flash id 指令示例如下:esptool.py --port com2 flash_id。 指令返回如下: Manufacturer: e0Device: 4016Detected flash size: 4MB 指令会返回当前 flash 的状态寄存器,将状态寄存器与 datasheet 作比较,可以定位当前 flash 问题的原因。 2.4. 串口连接 ESP8266 与 ESP32 通过 3.3V 的 UART 建立与 ROM 的通信连接。连接需要遵循以下规则:
注:不要将芯片连接到 5V TTL 电平,尤其是高电平的 RS-232!2.5. 进入 bootloader ESP8266 和 ESP32 进入 bootloader 之前均需要保证上电模式正确。 对于某些开发板(包括 NodeMCU, WeMOS, HUZZAH Feather, Core Board, ESP32-WROVER-KIT),esptool.py 可以自动地将上电启动模式配置正确。如果您使用的是上述开发板,可以跳过这一节。 在进入 bootloader 之前,需要做以下几件事:断电、将 pin 脚电平设置正确、GPIO 电平拉低,最后上电。 ESP8266 和 ESP32 每次上电重启时,均会重新选择工作模式。重启可以由以下几种方式触发:
注:对于 ESP8266,在工作状态时,nRESET 和 CH_PD 必须保持高电平。3. 常见问题及解答 3.1. bootloader 没有响应 如果你看到 ‘Failed to connect’ 字样,证明芯片没有进入到 bootloader。可以通过以下操作确认:
如果写 flash 中途出现问题,用较低波特率尝试。供电不稳定也有可能造成这个问题。 3.3. 写 flash 成功但无法运行
|
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
rk1126实现BT601输入,输入不带IIC接口的驱动程序
1196 浏览 0 评论
1203 浏览 1 评论
2296 浏览 3 评论
RK3568 Android11让系统ntp校准时间生效,需要设置些什么
3058 浏览 1 评论
5061 浏览 2 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-8-16 21:19 , Processed in 0.632641 second(s), Total 67, Slave 54 queries .
Powered by 电子发烧友网
© 2015 www.ws-dc.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号