This extension provides many features to ease development of ESP-IDF Projects.
- Quick Configure ESP-IDF Extension for first time user to help the user download, install and setup ESP-IDF and required tools within this Visual Studio Code extension.
- Quick prototyping by copying ESP-IDF examples with ESP-IDF: Show ESP-IDF Examples Projects.
- Syntax highlighting for KConfig and ESP-IDF Kconfig style syntax validation if
idf.useIDFKconfigStyle
is enabled. - GUI SDK Configuration Editor to configure your ESP-IDF project (esp-idf menuconfig).
- Partition Table Editor
- NVS Partition Editor
- Easily Build, Flash and Monitor your code with Espressif chips.
- OpenOCD server within Visual Studio Code.
- DEBUGGING with ESP-IDF Debug Adapter.
- Size analysis of binaries with ESP-IDF: Size Analysis of the Binaries.
- App tracing when using ESP-IDF Application Level Tracing Library like in ESP-IDF Application Level Tracing Example.
- Heap Tracing
- System View Tracing Viewer
- Localization (English, Chinese, Spanish) of commands which you can also add a language contribution.
- Code Coverage for editor source highlighting and generate HTML reports.
- Search text editor's selected text in ESP-IDF documentation with ESP-IDF: Search in Documentation... right click command or with its keyboard shortcut. Results will be shown in ESP-IDF Explorer Tab if found on ESP-IDF Documentation based on your current vscode language, ESP-IDF version in
idf.espIdfPath
(latest otherwise) andidf.adapterTargetName
. - ESP Rainmaker Support
- Core Dump and GdbStub postmortem mode.
- CMake Editor
- Support for WSL 2
The Add Arduino-ESP32 as ESP-IDF Component command will add Arduino-ESP32 as a ESP-IDF component in your current directory (${CURRENT_DIRECTORY}/components/arduino
). You can also use the ESP-IDF: Create Project from Extension Template command with arduino-as-component
template to create a new project directory that includes Arduino-esp32 as an ESP-IDF component.
NOTE Not all versions of ESP-IDF are supported. Make sure to check Arduino-ESP32 to see if your ESP-IDF version is compatible.
ESP-IDF: Build your Project is provided by this extension to build your project using CMake
and Ninja-build
as explained in ESP-IDF Build System Using Cmake Directly. You could modify the behavior of the build task with idf.cmakeCompilerArgs
for Cmake configure step and idf.ninjaArgs
for Ninja step. For example, using [-j N]
where N is the number of jobs run in parallel.
Click F5 to start debugging. To configure the debug behaviour, please review DEBUGGING.
NOTE For correct debug experience, first define the correct
idf.customExtraPaths
paths andidf.customExtraVars
using SETUP,build
your project, choose the right serial port,flash
the program to your device.
THIS WILL OVERRIDE ANY EXISTING CODE IN THE FILE WITH THE ONE GENERATED IN THE EDITOR. IF YOU HAVE ANY CODE NOT INCLUDED IN THE SCHEMA (OR SINGLE LINE COMMENTS) USE A REGULAR TEXT EDITOR INSTEAD
On CMakeLists.txt file right click this extension provides a custom CMakeLists.txt Editor to fill an ESP-IDF Project and Component registration as specified in ESP-IDF Project CMakeLists.txt and ESP-IDF Component CMakeLists.txt files. You need to choose which kind of CMakeLists.txt file (project or component) to edit. There is 2 types of input, one is a simple string and another is an array of strings, such as Component Sources (SRCS). All inputs are described in the CMakeLists.txt Schema (${this_repository}/src/cmake/cmakeListsSchema.json).
NOTE This editor doesn't support all CMake functions and syntaxes. This editor should only be used for simple CMakeLists.txt options such as component registration (using idf_component_register) and basic project elements. If you need more customization or advanced CMakeLists.txt, consider reviewing ESP-IDF Build System. Also review CMakeLists.txt Editor Schema for a list of supported code.
There are couple of custom tasks that the user can implement by using one of these configuration settings:
- Set
idf.customTask
to define a custom task to be executed with ESP-IDF: Execute Custom Task command or the activity bar icon. - Set
idf.preBuildTask
to define a custom task to be executed before ESP-IDF: Build your Project command task. - Set
idf.postBuildTask
to define a custom task to be executed after ESP-IDF: Build your Project command task. - Set
idf.preFlashTask
to define a custom task to be executed before Flash commands. - Set
idf.postFlashTask
to define a custom task to be executed after Flash commands.
The commands Select Flash Method and Flash, Flash (With JTag) using OpenOCD and JTAG or Flash (UART) your Project using the ESP-IDF esptool.py
as explained in ESP-IDF Build System Flash Arguments, are provided by this extension to flash your project. This command depends on the ${YOUR_PROJECT_DIR}/build/flasher_args.json
file generated by Build and the idf.flashBaudRate
configuration setting.
When you open a Kconfig
, Kconfig.projbuild
or Kconfig.in
file we provide syntax highlighting. If idf.useIDFKconfigStyle
is enabled, we also provide ESP-IDF Kconfig style syntax validation such as indent validation and not closing blocks found (Example: menu-endmenu). Please review Kconfig Formatting Rules and Kconfig Language for further details about the ESP-IDF Kconfig formatting rules and Kconfig language in general.
We support Log and Heap Tracing out of the box, which enables users to perform log/heap tracing with just few button clicks and present the results of tracing data with UI.
You can follow this quick step-by-step guide for Heap Tracing.
ESP-IDF: Monitor your Device is provided by this extension to start idf.py monitor
terminal program in Visual Studio Code. Please take a look at the IDF Monitor Documentation.
In Visual Studio Code, for ESP-IDF: Monitor your Device we use the shell executable given in vscode.env.shell
which is override by terminal.integrated.shell.*
in your Visual Studio Code Settings when using the Terminal: Select Default Shell
command to update the shell or updating terminal.integrated.shell.windows
for Windows, terminal.integrated.shell.osx
for MacOS and terminal.integrated.shell.linux
for Linux in VSCode Settings Preference menu (F1 -> Preferences: Open Settings (JSON)).
The user can start or stop the OpenOCD from Visual Studio Code using the ESP-IDF: OpenOCD Manager command or from the OpenOCD Server (Running | Stopped)
button in the Visual Studio Code status bar. The output is shown in menu View
-> Output
-> OpenOCD
. By default it will be launched using localhost, port 4444 for Telnet communication, port 6666 for TCL communication and port 3333 for Gdb.
Before using the OpenOCD server, you need to set the proper values for OpenOCD Configuration files in the idf.openOCDConfigs
configuration setting. You can choose a specific board listed in OpenOCD using ESP-IDF: Select OpenOCD Board Configuration or use ESP-IDF: Device Configuration to manually set any value you desire.
NOTE: The user can modify
openocd.tcl.host
andopenocd.tcl.port
configuration settings to modify these values. Please review ESP-IDF Settings to see how to modify these configuration settings.
The resulting OpenOCD server launch command looks like this: openocd -d${idf.openOcdDebugLevel} -f ${idf.openOcdConfigs} ${idf.openOcdLaunchArgs}
. The idf.openOcdDebugLevel
is a number used to define the OpenOCD Log Level (0-4) and idf.openOcdLaunchArgs
is a string array of any custom openOCD launch arguments the user wants to use.
Click theESP-IDF Explorer
in the Activity Bar. On the Device Partition Explorer
section, click the Refresh Partition Table
icon or the ESP-IDF: Refresh Partition Table
command in the Command Palette. This will get a list of the partitions listed in the Partition Table of your connected device and show them in the Device Partition Explorer
section. When you can any partition, you can choose to either open the Partition Table Editor (only when custom partition table is enabled) or choose a binary (.bin) file to flash on the selected partition. You can also right click any .bin
file and choose the partition in device to flash this partition.
This extension includes a GUI Menuconfig using the ESP-IDF: SDK Configuration Editor
command that reads your current project folder's sdkconfig
file (if available, otherwise it would take default values) and start the ESP-IDF JSON Configuration Server process (confserver.py in ${IDF_PATH}/tools) that enables the user to redefine ESP-IDF project and board configuration.
When the user modify a parameter value, the value is send to the confserver.py
process, which return the new value and other values modified to GUI Menuconfig and then update the values in the UI.
Values are not automatically saved to the SDKConfig file until you click save changes. You can cancel any changes and load the values from the SDKConfig file by clicking cancel changes. If you click set default the current SDKConfig file is replaced by a template SDKConfig file and then loaded into the GUI Menuconfig rendered values.
The search functionality allows to find a parameter by description, i.e the name that appears in the SDKConfig file.
An IDF GUI Menuconfig log in ESP-IDF
Output (Menu View -> Output) is created to print all communications with ${idf.espIdfPath}\tools\confserver.py
. It can be be used to track any errors.
NOTE: The ESP-IDF JSON Configuration Server is built from the project's
build/config/kconfig_menus.json
which is generated by the build system from ESP-IDF and user defined components Kconfig files on the first run of SDK Configuration Editor. This process takes a bit of time so we keep the process running in the background to speed things up. If you are making changes to any Kconfig files or you want to re-run the SDK Configuration Editor from scratch, you need to dispose the current process with theESP-IDF: Dispose Current SDK Configuration Editor Server Process
and run theESP-IDF: SDK Configuration Editor
again.
The ESP-IDF: Set Espressif Device Target allows the user to choose among Espressif different chips based on idf.py set-target.
When you use this command, the following files are set:
- Choosing
esp32
as IDF_TARGET will setidf.openOCDConfigs
to ["interface/ftdi/esp32_devkitj_v1.cfg", "target/esp32.cfg"] - Choosing
esp32s2
as IDF_TARGET will setidf.openOCDConfigs
to ["interface/ftdi/esp32_devkitj_v1.cfg", "target/esp32s2.cfg"] - Choosing
esp32s3
as IDF_TARGET will setidf.openOCDConfigs
to ["interface/ftdi/esp32_devkitj_v1.cfg", "target/esp32s3.cfg"] - Choosing
esp32c3
as IDF_TARGET will setidf.openOCDConfigs
to ["board/esp32c3-builtin.cfg"] if using built-in usb jtag or ["board/esp32c3-ftdi.cfg"] if using ESP-PROG-JTAG.
We have provide a System View Tracing Viewer inside the VS Code Extension which will enable you to view the traces along with other relevant details.