Introduction #
In this tutorial we will be looking at how get started with ESP32 development on Windows. We will be installing the Espressif IoT Development Framework (esp-idf), building a simple Hello World application and then programming it to an ESP32 development board. For this tutorial you’ll need:
- Windows PC
- with Python v3 installed
- Any ESP32 development board
- We will be using the ESP32-S2-Saola-1
ESP-IDF Installation #
Let’s start by installing ESP-IDF, which we’ll do by using Espressif’s ESP-IDF Tools Installer:
data:image/s3,"s3://crabby-images/bc6cc/bc6cca9beab47cf6fe1cf4db86866e336629e53c" alt="ESP-IDF Tools Installer Download"
Open up the installer we just downloaded and accept the license agreement and after the pre-installation system check, click Next. Start by either selecting an installation of Git on your system (as is the case for us), or select Install Git if you don’t already have it installed:
data:image/s3,"s3://crabby-images/bac5f/bac5faf4f4b5db9b6b5d969e9387bdd6776f33a9" alt="ESP-IDF Tools Installer - Git"
Click Next and Select Download ESP-IDF:
data:image/s3,"s3://crabby-images/9fcaf/9fcaf81b98108f6245c0ea1882e788bae6c38b4d" alt="ESP-IDF Tools Installer - ESP-IDF"
Click Next again and select the latest release version of ESP-IDF and select a location to download it to. We’ll be downloading version 4.2 to C:\esp-idf:
data:image/s3,"s3://crabby-images/5d497/5d49718e7b65d36de0d8e1986c02e745a6fb4412" alt="ESP-IDF Tools Installer - ESP-IDF Download"
Click Next and select a location to install the ESP-IDF Tools, we’ll be installing to C:\esp-idf-tools:
data:image/s3,"s3://crabby-images/21e34/21e347a816c16f1f9724eb31fbf8b197619d282b" alt="ESP-IDF Tools Installer - ESP-IDF Tools Download"
Click Next and select any shortcuts you’d like to create, leave Optimisation turned off and click Next. Finally we’ll get a summary of what we’re going to install:
data:image/s3,"s3://crabby-images/dc283/dc28345894a995ee03a685ec70fba27bb4cb50c0" alt="ESP-IDF Tools Installer - Summary"
If you’re happy with everything then click Install:
data:image/s3,"s3://crabby-images/6a0cd/6a0cd15aabeeb7809c74f95a184ac5b644d61ba8" alt="ESP-IDF Tools Installer - Install"
ESP-IDF Configuration #
Once installation is complete, ensure Run ESP-IDF Command Prompt Environment is selected and click Finish:
data:image/s3,"s3://crabby-images/3890f/3890fec99201bb25d782a14b189f3e5c175ee0d6" alt="ESP-IDF Tools Installer - Finish"
The command prompt will open and automatically add our ESP-IDF tools directories to the system PATH:
data:image/s3,"s3://crabby-images/9de6e/9de6e0b4f6b81343f65fd702b0861d0f2cd2ca0b" alt="Add ESP-IDF Tools to PATH"
Example Build – Command Line #
Now that we have everything setup, let’s build our first project from the command line. If you close the ESP-IDF Command Prompt and want to get back to it later, just find it in your Start Menu:
data:image/s3,"s3://crabby-images/a79db/a79db588974becd34e650fe6a21b622c74987a72" alt="ESP-IDF Command Prompt Start Menu Entry"
Navigate to examples\get-started\hello_world and if you are using an ESP32 skip to the next step. If you are using an ESP32-S2 like us, type: idf.py set-target esp32s2
data:image/s3,"s3://crabby-images/2501b/2501bb5a47f7af1292759aab9b2487c71355e395" alt="ESP-IDF Build Set Target"
Once done we can now build our project, so type: idf.py build
data:image/s3,"s3://crabby-images/c38c0/c38c09d730d22f9006c8bcc1412ea0f10c47e30f" alt="ESP-IDF Build"
Then wait for the project to build, this will take a few minutes:
data:image/s3,"s3://crabby-images/efe14/efe14f118ce1ae3694cb53ccc90dad3d8a6074eb" alt="ESP-IDF Building"
Once complete we can then flash our example project by typing idf.py -p (PORT) flash
where PORT is your the COM port of your ESP32 device, in our case this is COM15:
data:image/s3,"s3://crabby-images/275f9/275f94200e19c747780c8312589b1d01952c0698" alt="ESP-IDF Flashing"
Now open up a serial terminal and connect to your ESP32 device with a baudtrate of 115200 and you should see Hello World outputted after the device starts up:
data:image/s3,"s3://crabby-images/53f10/53f109d901a0856af66845cffae81c38a0b351a8" alt="Hello World Example Serial Output"
Example Project Config #
If you want to alter the baud rate of the serial output, Type: idf.py menuconfig
Then head to Serial Flasher Config > ‘idf.py monitor’ baud rate and change the baud rate to your preferred speed:
data:image/s3,"s3://crabby-images/9d9ae/9d9aee94e1167affedacc5c63b01db954904d778" alt="ESP-IDF Menuconfig"
Press Q on your keyboard to quit and press Y to save the configuration as we leave. Now we can re-build and re-flash. Type: idf.py -p (PORT) flash
Note that the flash command will automatically build the project again if needed.