ESP8266 常见固件烧写失败原因和解决方法

简介

在使用 ESP8266 进行开发时, 读者或多或少都能遇到固件烧写失败情况, 无论是官方提供的 windows 上 Flash 下载工具, 还是 SDK 中提供的 esptool.py.
下面笔者提供几种常见的烧写失败的原因和对应解决方法.

原因一: ESP8266 不在 UART boot

请通过 UART0 查看 ESP8266 上电打印:

 ets Jan 8 2013,rst cause:1, boot mode:(1,n)

UART boot 对应 boot mode 第一参数为 1, 此值由 [GPIO15, GPIO0, GPIO2] 决定.
GPIO15GPIO0 低电平, GPIO2 高电平.
boot mode 第一参数不为 1, 即不在烧写模式, 将无法烧写成功.
更加详细说明参考: ESP8266 基础篇: 启动时 rst cause 和 boot mode

参考解决办法:
不同模组/不同开发板解决方法不一而足, 但万变不离其宗, 即确保:
GPIO15 和 GPIO0 低电平, GPIO2 高电平

例如: ESP-Launcher 开发板, 需将 IO0 开关拨到 L 侧, CH_EN 开关拨到 H 侧.
有些开发板需按住 BOOT 按钮不放, 再短按 RST 按钮松开, 再松开 BOOT 按钮.
而后续的 ESP8266-DevKitC 则无需用户关心此问题.

原因二: 供压问题

常见供压问题如下:

  • 供压不稳
  • 供压过高
  • 供压不足

参考解决办法:
即最终确保模组 VCC(3V3) 和 GND 电压稳定在 3.3V.
通常可以使用独立供电的 HUB 来确保供压问题.

原因三: 串口配置错误

某些读者刚入门 Linux 或对 Windows /MacOS了解不深, 可能未配置对串口就开始烧写, 而导致烧写失败.通常, 开发板或模组通过 USB 插到 PC 上, 不同平台对应不同烧写口, 可以使用如下命令查看:

  • Linux: ls /dev/ttyUSB*
  • MacOS: ls /dev/tty.*
  • Windows: 计算机 -> 管理 -> 设备管理器 -> 端口 (COM 和 LPT)

参考解决办法:
LinuxMacOS 用户:

  • 通过在 make menuconfig -> Serial flasher config -> Default serial port 中配置对烧写口, 重新编译烧写.

Windows 用户:

  • Flash 下载工具 中通过 COM 口配置

原因四: 串口无写权限

某些读者可能通过虚拟机安装了 Linux 系统或 MacOS, 或某些权限管理较为严格的系统(某些公司管控 USB 设备), 经常串口无写权限, 需要用户手动去提升串口权限.

参考解决办法:

sudo chmod 777 /dev/ttyUSB*

其他非 Linux 平台类似.

原因五: 波特率配置过高

烧写速度受硬件影响, 在初步烧写失败情况下, 因降低烧写波特率.

参考解决办法:
make menuconfig -> Serial flasher config -> Default baud rate 配置为 115200
其他非 Linux 平台类似.

原因六: Flash SPI mode/speed 配置错误

ESP8266 芯片和固件本身支持: Flash SPI mode: QIO, QOUT, DIO, DOUT
ESP8266 芯片和固件本身支持 Flash SPI speed: 80MHz, 40MHz, 26.7MHz, 20MHz
但某些模组厂商, 基于 ESP8266 开发模组/开发板, 因成本或其他考虑, 未选型支持以上功能的 Flash, 导致某些读者使用此类型模组或开发板时需考虑此配置.

参考解决办法:
通常选择 QIO, 烧写失败时切换到 DIO, 切换方法:
make menuconfig -> Serial flasher config -> Flash SPI mode 切换 SPI mode
make menuconfig -> Serial flasher config -> Flash SPI speed 切换 SPI speed

其他非 Linux 平台类似.

原因七: 使用非官方烧写工具

某些读者可能基于其他公司的 第三方工具/IDE进行二次开发甚至更下游开发.
如遇到烧写失败情况, 也可能是 第三方工具/IDE 本身问题. 如下截图所示, 某博客写到:
ESP8266 常见固件烧写失败原因和解决方法_第1张图片
初步来看, 应是第三方工具在烧写模式时, 未对 [GPIO15, GPIO0, GPIO2] 电平做出较为优雅的配置, 导致需重新插拔进行烧写.

参考解决办法:
建议使用官方提供的 windows 上 Flash 下载工具, 或 SDK 中提供的 make flash 进行烧写固件.

原因八: 模组 TX RX GND 接线错误

开发板通常不存在此类情况, 模组需考虑此种情况.

  • 模组接线错误: TX, RX, GND 未接到对应 RXD, TXD, GND 或其他接线错误

参考解决办法:
根据官方 datasheet 重新布线.

原因九: 其他原因

往往, 电脑或个人原因, 或多或少偶尔遇到一些奇怪的烧写错误原因, 这里记录一下, 供读者参考:

  • ESP8266 固件烧写到 ESP32

其他参考解决办法

  • 重启电脑
  • 换个 USB线/USB转TTL
  • 换个 模组/开发板
  • 使用官方 SDKrelease 版本进行烧写测试
  • 向我们提 issues

你可能感兴趣的:(ESP8266 常见固件烧写失败原因和解决方法)