Getting started with the ESP-IDF running under WSL2

ESP32 Development board ESP32 Development board

I’m really excited about this post, because it’s the first post slightly related to Embedded Systems, and that’s the topic I was expecting to write about when I started this blog. The second reason is because I love the ESP32, specially using the ESP IoT Development Framework. It’s been a while since I worked with an ESP32 using the IDF (2019 actually), and the framework changed a lot since, so after all this time, I decided to get myself a dev board and explore the IDF again.

When I started working with the ESP32, I followed the excellent Neil Kolban’s Book on ESP32, but I’ve heard it’s slightly outdated now, so your best bet is definitely the also excelent IDF Documentation from Espressif.

As I wrote before, I’ve been using mostly Windows 10 with WSL2 for my development work, so setting up the IDF under WSL2 might be a little different to the average process you follow if running under an actual Linux distribution. This guide is a quick guide on how to start working with an ESP32 using WSL2.

1. Install the CP210x USB to UART Bridge VCP Drivers

Assuming you’re using one of the very common ESP32 DevKit Boards, you’ll need the drivers for the on-board programming chip. You can download them and easily install them from Silicon Lab’s website.

After installing the drivers, connect your development board using an USB cable, and you should be able to see your board and the related serial (COM) port under Device Manager.

CP210x USB to UART Bridge showing under Device Manager

CP210x USB to UART Bridge showing under Device Manager

2. Make sure you’re running Python 3 and esptools in Windows

You must have Python 3 in both your WSL subsystem and Windows itself.

> python --version
Python 3.9.4

You also need esptool installed in your Windows Python environment, so open up PowerShell or your shell of choice and install the package using pip:

pip install esptool --user

3. Install idfx in your WSL2 system

idfx is a simple tool made by abobija that lets you interact with your ESP32 from WSL2. Installation is pretty simple:

wget -O $HOME/.local/bin/idfx && chmod u+x $HOME/.local/bin/idfx

Check the project’s page to learn how to use the tool.

Remember to add $HOME/.local/bin/ to your PATH variable, if you don’t, your shell won’t be able to run idfx:

$ idfx --help
zsh: command not found: idfx

4. Install the ESP-IDF dependencies on your WSL2 subsystem

Follow the steps found on the Standard Setup of Toolchain for Linux page from Espressif’s documentation. Ignore the permission issues part.

Assuming you’re using Ubuntu (or Debian):

sudo apt-get install git wget flex bison gperf python3 python3-pip python3-setuptools cmake ninja-build ccache libffi-dev libssl-dev dfu-util libusb-1.0-0

5. Get the ESP-IDF and install it

In your WSL2 subsystem, clone the IDF repo using Git:

mkdir -p ~/esp
cd ~/esp
git clone --recursive

Then, run the install script:

cd ~/esp/esp-idf

Finally, source the environment variables:

. $HOME/esp/esp-idf/

Tip: If you’re planning to use the IDF frequently, create an alias for the export script under your .bashrc or .zshrc:

alias get_idf='. $HOME/esp/esp-idf/'

Taken from Espressif’s documentation

6. Build a project

Let’s start with a good ol’ Hello World. The IDF provides a lot of examples you can use to get yourself started. Let’s use the hello-world project:

cd ~/esp
cp -r $IDF_PATH/examples/get-started/hello_world .

If you exported your environment variables, you should have access to the tool, the central part of the IDF:

cd ~/esp/hello_world set-target esp32 # Configures the project for the ESP32 menuconfig # Opens the configuration menu

You can change the configuration all you want, but I’ll go with the default configuration and just press “Q” and save.

ESP-IDF menuconfig

ESP-IDF menuconfig

Then, build the project: build

Once that’s done, use idfx to flash and monitor the ESP32’s serial output:

idfx flash COM3

(You can find your COM port’s number by looking at the Device Manager).

idfx monitor COM3

If you did everything right, you should be getting output from the ESP32: ESP32 serial output

ESP32 serial output

And that’s it! You should now have all you need to play around with the IDF and build cool stuff. Thanks for reading, hope this is useful, and see you next time!