Using ESP-IDF in Custom CMake Projects

This example illustrates using ESP-IDF components as libraries in custom CMake projects. This builds an equivalent application to the hello_world example under examples/get-started/hello_world.

Example Flow

Users looking at this example should focus on the top-level CMakeLists.txt file. This builds an application that can run on targets without relying on the typical ESP-IDF application template. The application itself follows a similar code flow to the aforementioned hello_world example.

Output

Hello world!
This is ESP32 chip with 2 CPU cores, WiFi/BT/BLE, silicon revision 0, 4MB external flash
Restarting in 10 seconds...
Restarting in 9 seconds...
Restarting in 8 seconds...
Restarting in 7 seconds...
Restarting in 6 seconds...
Restarting in 5 seconds...
Restarting in 4 seconds...
Restarting in 3 seconds...
Restarting in 2 seconds...
Restarting in 1 seconds...
Restarting in 0 seconds...

Building this Example

To build this example, run the following commands from this directory:

# Create a build directory, and change location to that directory.
mkdir build; cd build
# Invoke CMake, specifying the top-level CMakeLists.txt directory and toolchain file to use. This will generate
# the build system files.
cmake .. -DCMAKE_TOOLCHAIN_FILE=$IDF_PATH/tools/cmake/toolchain-esp32.cmake -DIDF_TARGET=esp32
# Build using the generated build system files.
cmake --build .

Or, execute build.sh script, which contains the same commands mentioned above.

Flashing and Running this Example

To flash this example, we will have to invoke esptool.py and idf_monitor.py manually. While still in the build directory:

Flashing to target

# Write project binaries to flash.
esptool.py --port /dev/ttyUSB0 write_flash @flash_project_args

Running on target

# Monitor the output of the flashed firmware.
idf_monitor.py --port /dev/ttyUSB0 idf_as_lib.elf

Of course, you should replace the specified ports in the commands specified above to the proper one where your device is connected.


There is a discussion on using ESP-IDF in custom CMake projects in the programming guide under API Guides -> Build System (CMake) -> Using ESP-IDF in Custom CMake Projects