Downloading Guide
This Guide demonstrates how to download AT firmware and flash it into an ESP32-WROOM-32 device by taking ESP32-WROOM-32 as an example. The Guide is also applicable to other ESP32 modules.
Before you start, please make sure you have already connected your hardware. For more details, see Hardware Connection.
For different series of modules, the commands supported by AT firmware are different. Please refer to ESP-AT Firmware Differences for more details.
Download AT Firmware
To download AT firmware to your computer, please do as follows:
Navigate to AT Binary Lists
Find the firmware for your device
Click the link to download it
Here, we download ESP32-WROOM-32_AT_Bin_V2.2.0.0
for ESP32-WROOM-32. The list below describes the structure of this firmware and what each bin file contains. Other AT firmware has similar structure and bin files.
.
├── at_customize.bin // secondary partition table
├── bootloader // bootloader
│ └── bootloader.bin
├── customized_partitions // AT customized binaries
│ ├── ble_data.bin
│ ├── client_ca.bin
│ ├── client_cert.bin
│ ├── client_key.bin
│ ├── factory_param.bin
│ ├── factory_param_WROOM-32.bin
│ ├── mqtt_ca.bin
│ ├── mqtt_cert.bin
│ ├── mqtt_key.bin
│ ├── server_ca.bin
│ ├── server_cert.bin
│ └── server_key.bin
├── download.config // configuration of downloading
├── esp-at.bin // AT application binary
├── esp-at.elf
├── esp-at.map
├── factory // A combined bin for factory downloading
│ ├── factory_WROOM-32.bin
│ └── factory_parameter.log
├── flasher_args.json // flasher arguments
├── ota_data_initial.bin // ota data parameters
├── partition_table // primary partition table
│ └── partition-table.bin
├── phy_init_data.bin // phy parameters
└── sdkconfig // compilation configuration for AT firmware
The file download.config
contains the configuration to flash the firmware into multiple addresses:
--flash_mode dio --flash_freq 40m --flash_size 4MB
0x8000 partition_table/partition-table.bin
0x10000 ota_data_initial.bin
0xf000 phy_init_data.bin
0x1000 bootloader/bootloader.bin
0x100000 esp-at.bin
0x20000 at_customize.bin
0x24000 customized_partitions/server_cert.bin
0x39000 customized_partitions/mqtt_key.bin
0x26000 customized_partitions/server_key.bin
0x28000 customized_partitions/server_ca.bin
0x2e000 customized_partitions/client_ca.bin
0x30000 customized_partitions/factory_param.bin
0x21000 customized_partitions/ble_data.bin
0x3B000 customized_partitions/mqtt_ca.bin
0x37000 customized_partitions/mqtt_cert.bin
0x2a000 customized_partitions/client_cert.bin
0x2c000 customized_partitions/client_key.bin
--flash_mode dio
means the firmware is compiled with flash DIO mode.--flash_freq 40m
means the firmware’s flash frequency is 40 MHz.--flash_size 4MB
means the firmware is using flash size 4 MB.0x10000 ota_data_initial.bin
means downloadingota_data_initial.bin
into the address0x10000
.
Flash AT Firmware into Your Device
Follow the instructions below for your operating system.
Windows
Before starting to flash, you need to download Flash Download Tools for Windows. For more details about the tools, please see the doc
folder in the zip folder.
Open the ESP32 Flash Download Tool.
Select chipType. (Here, we select
ESP32
.)Select a workMode according to your need. (Here, we select
Developer Mode
.)Select a loadMode according to your need. (Here, we select
uart
.)
Flash AT firmware into your device. You can select either of the two ways below.
In case of flashing issues, please verify what the COM port number of download interface of the ESP32 board is and select it from “COM:” dropdown list. If you don’t know the port number, you can refer to Check port on Windows for details.
When you finish flashing, please Check Whether AT Works.
Linux or macOS
Before you start to flash, you need to install esptool.py.
You can select either of the two ways below to flash AT firmware into your device.
To download the bins separately into multiple addresses, enter the following command and replace
PORTNAME
anddownload.config
:esptool.py --chip auto --port PORTNAME --baud 115200 --before default_reset --after hard_reset write_flash -z download.config
Replace
PORTNAME
with your port name. If you don’t know it, you can refer to Check port on Linux and macOS for details.Replace
download.config
with the content inside the file.Below is the example command for ESP32-WROOM-32.
esptool.py --chip auto --port /dev/tty.usbserial-0001 --baud 115200 --before default_reset --after hard_reset write_flash -z --flash_mode dio --flash_freq 40m --flash_size 4MB 0x8000 partition_table/partition-table.bin 0x10000 ota_data_initial.bin 0xf000 phy_init_data.bin 0x1000 bootloader/bootloader.bin 0x100000 esp-at.bin 0x20000 at_customize.bin 0x24000 customized_partitions/server_cert.bin 0x39000 customized_partitions/mqtt_key.bin 0x26000 customized_partitions/server_key.bin 0x28000 customized_partitions/server_ca.bin 0x2e000 customized_partitions/client_ca.bin 0x30000 customized_partitions/factory_param.bin 0x21000 customized_partitions/ble_data.bin 0x3B000 customized_partitions/mqtt_ca.bin 0x37000 customized_partitions/mqtt_cert.bin 0x2a000 customized_partitions/client_cert.bin 0x2c000 customized_partitions/client_key.bin
To download the bins together to one address, enter the following command and replace
PORTNAME
andFILEDIRECTORY
:esptool.py --chip auto --port PORTNAME --baud 115200 --before default_reset --after hard_reset write_flash -z --flash_mode dio --flash_freq 40m --flash_size 4MB 0x0 FILEDIRECTORY
Replace
PORTNAME
with your port name. If you don’t know it, you can refer to Check port on Linux and macOS for details.Replace
FILEDIRECTORY
with the file directory you would flash to the address0x0
. It is normally factory/XXX.bin.Below is the example command for ESP32-WROOM-32.
esptool.py --chip auto --port /dev/tty.usbserial-0001 --baud 115200 --before default_reset --after hard_reset write_flash -z --flash_mode dio --flash_freq 40m --flash_size 4MB 0x0 factory/factory_WROOM-32.bin
When you finish flashing, please Check Whether AT Works.
Check Whether AT Works
To check whether AT works, do as follows:
Open a serial port tool, such as SecureCRT;
Select the Port attached to “AT command/response” line (see Hardware Connection for details);
Set Baudrate to 115200;
Set Data Bits to 8;
Set Parity to None;
Set Stop Bits to 1;
Set Flow Type to None;
Enter the command “AT+GMR” with a new line (CR LF).
If the response is OK as the picture below shows, AT works.
Otherwise, you need to check your ESP32 startup log, which is visible on PC over “Download/Log output connection”. If it is like the log below, it means that ESP-AT firmware have been initalized correctly.
ESP32 startup log:
ets Jun 8 2016 00:22:57
rst:0x1 (POWERON_RESET),boot:0x13 (SPI_FAST_FLASH_BOOT)
configsip: 0, SPIWP:0xee
clk_drv:0x00,q_drv:0x00,d_drv:0x00,cs0_drv:0x00,hd_drv:0x00,wp_drv:0x00
mode:DIO, clock div:2
load:0x3fff0030,len:7168
load:0x40078000,len:13200
load:0x40080400,len:4564
0x40080400: _init at ??:?
entry 0x400806f4
I (26) boot: ESP-IDF v4.2.2-76-gefa6eca 2nd stage bootloader
I (26) boot: compile time 11:54:30
I (26) boot: chip revision: 1
I (30) boot_comm: chip revision: 1, min. bootloader chip revision: 0
I (37) boot.esp32: SPI Speed : 40MHz
I (42) boot.esp32: SPI Mode : DIO
I (46) boot.esp32: SPI Flash Size : 4MB
I (51) boot: Enabling RNG early entropy source...
I (56) boot: Partition Table:
I (60) boot: ## Label Usage Type ST Offset Length
I (67) boot: 0 phy_init RF data 01 01 0000f000 00001000
I (75) boot: 1 otadata OTA data 01 00 00010000 00002000
I (82) boot: 2 nvs WiFi data 01 02 00012000 0000e000
I (90) boot: 3 at_customize unknown 40 00 00020000 000e0000
I (97) boot: 4 ota_0 OTA app 00 10 00100000 00180000
I (105) boot: 5 ota_1 OTA app 00 11 00280000 00180000
I (112) boot: End of partition table
I (117) boot_comm: chip revision: 1, min. application chip revision: 0
I (124) esp_image: segment 0: paddr=0x00100020 vaddr=0x3f400020 size=0x285f8 (165368) map
I (196) esp_image: segment 1: paddr=0x00128620 vaddr=0x3ffbdb60 size=0x03934 ( 14644) load
I (202) esp_image: segment 2: paddr=0x0012bf5c vaddr=0x40080000 size=0x040bc ( 16572) load
I (210) esp_image: segment 3: paddr=0x00130020 vaddr=0x400d0020 size=0x109f40 (1089344) map
I (626) esp_image: segment 4: paddr=0x00239f68 vaddr=0x400840bc size=0x1aa04 (109060) load
I (674) esp_image: segment 5: paddr=0x00254974 vaddr=0x400c0000 size=0x00064 ( 100) load
I (691) boot: Loaded app from partition at offset 0x100000
I (691) boot: Disabling RNG early entropy source...
module_name:WROOM-32
max tx power=78,ret=0
2.2.0