Skip to content

Instantly share code, notes, and snippets.

@abobija
Last active September 15, 2024 19:54
Show Gist options
  • Save abobija/2f11d1b2c7cb079bec4df6e2348d969f to your computer and use it in GitHub Desktop.
Save abobija/2f11d1b2c7cb079bec4df6e2348d969f to your computer and use it in GitHub Desktop.
ESP-IDF on WSL2 - Build, Flash and Monitor

ESP-IDF on WSL2 - Build, Flash and Monitor ⚡

Demo

How to setup ESP-IDF on WSL2 Ubuntu 20.04 - Config, Build and Flash

Intro

WSL2 still does not support USB devices, but with a little effort we can make possible to flash and monitor ESP device from WSL2.

Info:
Tested on Ubuntu 20.04 LTS and Debian distributions.

For flashing and monitoring over the serial COM port, I've wrote this compact idfx shell script.

Note:
As a prerequisite for using idfx, Python 🐍 needs to be installed on the Windows.

More about idfx you can find in official repository.

Ok, that was short intro, now you can open WSL and start to execute next commands.

Commands 📜

Installation 🚀

  • Update Linux
    sudo apt update && sudo apt upgrade -y

  • Install tools required for esp-idf
    sudo apt install -y git wget curl flex bison gperf python3 python3-pip python3-venv cmake ninja-build ccache libffi-dev libssl-dev dfu-util libusb-1.0-0

  • Make python3 as default python
    sudo update-alternatives --install /usr/bin/python python /usr/bin/python3 1

  • Make pip3 as default pip
    sudo update-alternatives --install /usr/bin/pip pip /usr/bin/pip3 1

  • Make esp directory and go inside
    cd ~ && mkdir esp && cd esp

  • Clone esp-idf repository
    git clone --recursive https://github.com/espressif/esp-idf.git

  • Modify esp-idf installation script to work with WSL
    cd esp-idf && ! grep -q "dirname --" install.sh; [ $? -eq 0 ] && sed -i 's/dirname/dirname --/g' install.sh

  • Run esp-idf installation script
    . ./install.sh || true

  • Add esp-idf export script to the user profile script in order to make isp-idf tools visible on the PATH for every session
    echo -e '\n\n. $HOME/esp/esp-idf/export.sh > /dev/null 2>&1 || true' >> ~/.profile

  • Install idfx ( ? )
    curl https://git.io/JyBgj --create-dirs -L -o $HOME/bin/idfx && chmod u+x $HOME/bin/idfx

  • Source profile script to add all necessary tools to the PATH
    . ~/.profile || true

Create (a copy of hello_world) project 📄

  • Make a copy of hello_world example project in home directory
    cd ~ && cp -r $IDF_PATH/examples/get-started/hello_world .

Build, flash and monitor ⚡

  • Go inside of project
    cd hello_world

  • Set target
    idf.py set-target esp32

  • Configure
    idf.py menuconfig

  • Build
    idf.py build

  • Flash
    (open Device Manager on Windows to find COM port of your ESP, mine is COM2)
    idfx flash COM2

  • Monitor
    (change COM2 with your port)
    idfx monitor COM2
    (To exit monitor press CTRL+] or CTRL+T,X)

Tip:
Flash and monitor with single command:
idfx flash COM2 monitor


That's it.
Happy coding and flashing! ⚡

idfx preview

Author

abobija - abobija.com

@Haoyu-R
Copy link

Haoyu-R commented Feb 16, 2021

Nice work. How could we use this in PlatformIO IDE?

@abobija
Copy link
Author

abobija commented Feb 16, 2021

@Haoyu-R thanks and sorry but I have no experience with PlatformIO

@mstahl
Copy link

mstahl commented Jun 29, 2021

Nice work! Saved me a bunch of heartache.

@sunshine-nick
Copy link

sunshine-nick commented Dec 12, 2021

WOW. i have been looking for a quick fix for this problem for a while. Eventually resorted to installing the very recent usbip version from MS and still didnt have any luck. Just problems. then i found this I am not a python person and done how how it works. But ot just does. The biggest problem is get pip installed on windows. After that just follw the instructions here.
I reccomend this to anyone wanting/needing to develop ESP32 on WSL2..... and WSL2 is so fast in comparision to WSL ... you need this. Well done Abobija. This should be added to the ESpressif IDF as the offcial solution.

@adrobot1314
Copy link

adrobot1314 commented Jun 27, 2022

Thank you for posting this! I am really new to this so this could be some issue on my part but when I try the install idfx step I get this error "/home/adrobot1314/.local/bin/idfx: No such file or directory". Would you happen to know how to fix it? I also tried this on a different computer and ran into the same error. @abobija

@Paul-Simpson
Copy link

Thank you - this works!

@Takewi
Copy link

Takewi commented May 3, 2023

Thanks!

@samsteele2
Copy link

This worked great for me. Thanks a bunch.

@midiexiangxxx
Copy link

thanks,this works!

@merinkumar
Copy link

thanks for the post, but am stuck at the flash stage, after i give Y to install esptool i get the error. and i have python 11.x in win11 installed.

error: Installing collected packages: bitarray, six, PyYAML, pycparser, bitstring, ecdsa, cffi, cryptography, esptool
WARNING: Failed to write executable - trying to use .deleteme logic
ERROR: Could not install packages due to an OSError: [WinError 2] The system cannot find the file specified: 'C:\Python311\Scripts\esp_rfc2217_server.exe' -> 'C:\Python311\Scripts\esp_rfc2217_server.exe.deleteme'

@nils-jansen
Copy link

Thanks a lot for this, works well :)

@hetal-mpc
Copy link

Thanks,
I was able to flash using idfx flash COM2 but for monitor commands idfx monitor COM2 getting below error:
C:\Users\abc\AppData\Local\Programs\Python\Python310\python.exe: can't open file '\\wsl$\Ubuntu\mnt\e\projects\esp-idf\tools\idf_monitor.py': [Errno 13] Permission denied

@akauppi
Copy link

akauppi commented Jan 1, 2024

Just letting you know:

I've made a similar repo https://github.com/lure23/ESP32-WSL which uses USBIP for communicating with the device, from WSL2. It requires minimum installations on the host (Windows) side, which was one of my design criteria. This is where it differs from the work in this repo. Perhaps someone who has problems finds it a way further. cc @hetal-mpc

@1078249029
Copy link

Thank you very much!

@CoolNamesAllTaken
Copy link

This is awesome, thank you! <3

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment