This is an example repository to quickly get you debugging an ESP32-based dev board with the ESP-Prog programmer in VSCode.
Includes VSCode tasks out of the box for:
- Building firmware
- Flashing firmware to your device
- Starting a debug session
- Monitoring your device over serial
- Cleaning your build folder
If you are starting a new project from scratch you can clone this repo directly and use it as a bare bones base to build on top of. After cloning, follow the instructions under the Setup and Configuration sections below.
If you already have an existing ESP32 firmware project setup in VSCode it is very simple to integrate pieces of this repository into your project. The core functionality to enable debugging is provided by 3 files in the .vscode folder.
- launch.json - Contains the debug configuration
- settings.json - Contains environment-specific paths to various tools required for building and debugging
- tasks.json - Defines tasks for building, flashing, monitoring, and debugging
If you don't have any of these files in your existing repo simply copy all of them into your .vscode folder. If you have a launch.json file I highly recommend you simply replace it with the file in this repo.
If you already have a tasks and settings file you can simply add the contents from the corresponding files in this repo to yours.
Name: C/C++
Id: ms-vscode.cpptools
Description: C/C++ IntelliSense, debugging, and code browsing.
Version: 1.9.7
Publisher: Microsoft
VS Marketplace Link: https://marketplace.visualstudio.com/items?itemName=ms-vscode.cpptools
If you don't already have it you will need to clone the ESP-IDF repo to a location of your choice on your machine. You will need the path to this location later on.
git clone --recursive https://github.com/espressif/esp-idf.git -b v5.0
NOTE: If branch does not exist yet, then simply use
master
(v5.0 and higher required M1 Mac support).
The configuration instructions below assume you have already installed the ESP-IDF toolchain. Instructions for installing the toolchain can be found here.
Due to some issues with Python versions in the ESP-IDF tooling, you must have the Python 2.7 dependencies installed on your machine even if you have configured ESP-IDF to use Python 3.
On Linux, you may install libpython2.7
with the following command.
sudo apt-get install libpython2.7
To configure the tasks and debug configuration there are a few tweaks you need to make to the files in the .vscode directory as follows.
-
esp_idf_path - The ESP IDF path is set in $IDF_PATH after running
. export.sh
(default:~/esp/esp-idf
).The value in
esp_idf_path
has been defaulted based on the instructions provided by ESP regarding tool installation. see: https://docs.espressif.com/projects/esp-idf/en/latest/esp32/get-started/index.html#step-3-set-up-the-tools
If you cloned this repository directly to start a new project this file does not need to be changed. Proceed to the next section.
If you added this file to an existing project you need to change the target attribute to point to the elf file created during a firmware build. It will be named based on what you call your project in the top-level CMakeLists.txt file.
No changes need to be made to this file.
NOTE: One thing I encountered was both the ESP32 target device as well as the ESP-Prog will enumerate as
/dev/ttyUSB0
if plugged in first on Linux. Since the debug commands rely on the target device port being constant it's important that you plug in the target device first if you've configured settings.json to use/dev/ttyUSB0
as the flash and monitor port.
ESP-Prog Connector Pinout Diagram:
- Attach the ESP-Prog to your target device via whatever JTAG cable is required.
- Plug the target device (the one you want to debug) into your computer.
- Click Terminal > Run Tasks... to open the Task list in VSCode and select Flash and Monitor Device.
- The device should successfully flash and start showing serial output, if applicable.
- Plug the ESP-Prog into your computer. The red LED should illuminate.
- Start a debug session with F5 or Run->Start Debugging from the menu.
From this state you can makes changes and flash new firmware. Starting a new debug session will reset and halt your device at your application entry point.
I've found this to be a very reliable approach to debugging my ESP32 device. However, occasionally things will stop working and it won't be clear why. The 'ol "turn it off and back on again" is pretty effective here. To fix almost any issues:
- Make sure the debugger is stopped by hitting the Red square from the debug panel, hitting Shift-F5 or Run->Stop Debugging from the menu.
- Stop OpenOCD by focusing the OpenOCD shell output window and hitting Ctrl-C.
- Try to start debugging again.
If you get the following error when trying to flash your device:
A fatal error occurred: Timed out waiting for packet content
CMake Error at run_cmd.cmake:14 (message):
esptool.py failed
Call Stack (most recent call first):
run_esptool.cmake:21 (include)
This can be due to the fact that your target device is not at the /dev/ttyXXX
path you have set in settings.json. See the note above about plug-in order.
Another thing to try is to disconnect your ESP-Prog and try to flash your device
without the ESP-Prog connected. After successful flash you can reconnect the
ESP-Prog to your computer.
The main branch of this repo is configured to work with version 5.0 of ESP-IDF. If you are using a different version of IDF it is very likely that paths in the settings.json file will need to be altered to match the various toolchain versions.
This information is the result of hours upon hours of research and trial and error and is provided free to the community to hopefully help other ESP32 makers. That said, if you found this helpful or if it saved you time and you wanna say thanks in the form of a burrito, well, I'm not gonna stop you.
Buy Me a Burrito 🌯🌯🌯