Using Espressif IoT Development Framework with the ESP32

Prerequisites

Configuring your project

make menuconfig

Compiling your project

make app

Flashing the Bootloader

ESP32 has a bootloader in ROM which runs after reset, but ESP-IDF also uses a second stage software bootloader. The ROM bootloader loads the software bootloader, which then loads the firmware app of the ESP32. The software bootloader must be flashed to offset 0x5000 in the flash.

To build the software bootloader, navigate to your project's top-level directory and run:

make bootloader

If you've configured the serial port details in make menuconfig, then

make bootloader-flash

... will automatically run esptool.py to flash the image. Otherwise, you can customise the esptool.py command that is printed out as part of make bootloader.

You only need to flash the ESP32 bootloader once.

The Partition Table

Once you've compiled your project, the "build" directory will contain a binary file with a name like "my_app.bin". This is an ESP32 image binary that can be loaded by the bootloader.

A single ESP32's flash can contain multiple apps, as well as many different kinds of data (calibration data, filesystems, parameter storage, etc). For this reason a partition table is flashed to offset 0x4000 in the flash.

Each entry in the partition table has a name (label), type (app, data, or something else), subtype and the offset in flash where the partition is loaded.

The simplest way to use the partition table is to make menuconfig and choose one of the simple predefined partition tables:

  • "Single factory app, no OTA"
  • "Factory app, two OTA definitions"

In both cases the factory app is flashed at offset 0x10000. If you make partition_table then it will print a summary of the partition table.

For more details about partition tables and how to create custom variations, view the docs/partition_tables.rst file.

Description
Espressif IoT Development Framework. Official development framework for Espressif SoCs.
https://docs.espressif.com/projects/esp-idf/en/stable/esp32/index.html
Readme 384 MiB
Languages
C 95.6%
Python 2.1%
C++ 1.2%
CMake 0.7%
Assembly 0.3%