- Self-configuration
- Setup wizard
- Extension manual configuration using Preferences: Open Settings (JSON)
- Extension manual configuration using Preferences: Open Settings (UI)
- Extension configuration example
NOTE: Make sure to install the extension prerequisites and, if using WSL2, the required packages specified in WSL Documentation.
When you start ESP-IDF extension, it will try to self-configure by looking for existing ESP-IDF directory in IDF_PATH
environment variable, $HOME/esp/esp-idf
on MacOS/Linux and %USERPROFILE%\esp\esp-idf
or %USERPROFILE%\Desktop\esp-idf
in Windows. It will look for ESP-IDF Tools and ESP-IDF Python virtual environment in IDF_TOOLS_PATH
environment variable, $HOME\.espressif
on MacOS/Linux and %USERPROFILE%\.espressif
on Windows.
If ESP-IDF and corresponding ESP-IDF tools are found, these paths will be saved as Visual Studio Code Configuration settings, which are located in Command Palette (F1 or View Menu -> Command Palette) and type Preferences: Open Settings (UI)
or Command Palette (F1 or View Menu -> Command Palette) and type Preferences: Open Settings (JSON)
.
These settings, as described in ESP-IDF Specific Settings, are:
idf.espIdfPath
for IDF_PATH,idf.customExtraPaths
for ESP-IDF Tools paths to be appended to environment variable PATH,idf.pythonBinPath
for absolute virtual environment python path andidf.customExtraVars
for additional environment variables from ESP-IDF tools such as OPENOCD_SCRIPTS.
NOTE: Visual Studio Code has many places where to set configuration settings. This extension uses the
idf.saveScope
configuration setting to determine where to save settings, Global (User Settings), Workspace and WorkspaceFolder. Please review the visual studio code settings precedence.
If ESP-IDF and ESP-IDF tools are not available, you can use the Setup Wizard to download them and configure the extension for you or manually configure the extension as explained in JSON Manual Configuration or Settings UI Manual Configuration .
With Visual Studio Code Command Palette (F1 or View Menu -> Command Palette) and type ESP-IDF: Configure ESP-IDF extension.
Setup wizard provides 3 choices:
- Express install: Fastest option.
- Choose to either download selected ESP-IDF version or find ESP-IDF in your system.
- Download and install ESP-IDF Tools. This step will use the existing value in
idf.toolsPath
oridf.toolsPathWin
as ESP-IDF Tools directory. - Create python virtual environment with required packages on existing ESP-IDF Tools directory.
- Advanced install: Configurable option.
- Choose to either download selected ESP-IDF version or find ESP-IDF in your system.
- Download or use existing ESP-IDF Tools:
- Choose directory for ESP-IDF Tools and install ESP-IDF Tools. This step will update the existing value in
idf.toolsPath
oridf.toolsPathWin
. - Specify directory than contains executable for each required ESP-IDF tool with matching version.
- Choose directory for ESP-IDF Tools and install ESP-IDF Tools. This step will update the existing value in
- Create python virtual environment with required packages in chosen ESP-IDF Tools directory.
- Use existing setup: This option will use an existing setup if:
esp-idf.json
is found in the currentidf.toolsPath
(MacOS/Linux users) oridf.toolsPathWin
(Windows users). This file is generated when you install ESP-IDF with the IDF Windows installer or using IDF-ENV.- ESP-IDF is found in
idf.espIdfPath
oridf.espIdfPathWin
,IDF_PATH
environment variable,$HOME/esp/esp-idf
on MacOS/Linux and%USERPROFILE%\esp\esp-idf
or%USERPROFILE%\Desktop\esp-idf
in Windows. - ESP-IDF Tools and ESP-IDF Python virtual environment for the previous ESP-IDF are found in
idf.toolsPath
oridf.toolsPathWin
,IDF_TOOLS_PATH
environment variable,$HOME\.espressif
on MacOS/Linux and%USERPROFILE%\.espressif
on Windows.
NOTE: When running any of these choices, the setup wizard will install ESP-IDF Python packages, this extension (
EXTENSION_PATH
/requirements.txt and ESP-IDF debug adapter (EXTENSION_PATH
/esp_debug_adapter/requirements.txt) python packages whereEXTENSION_PATH
is:
- Windows:
%USERPROFILE%\.vscode\extensions\espressif.esp-idf-extension-VERSION
- Linux & MacOSX:
$HOME/.vscode/extensions/espressif.esp-idf-extension-VERSION
so make sure that if using an existing python virtual environment that installing these packages doesn't affect your virtual environment.
NOTE: Currently the python package
pygdbmi
used by the debug adapter still depends on some Python 2.7 libraries (libpython2.7.so.1.0) so make sure that the Python executable inidf.pythonBinPath
you use contains these libraries. This will be dropped in later versions of ESP-IDF.
NOTE: Make sure that
IDF_PATH
andIDF_TOOLS_PATH
doesn't have any spaces to avoid any build issues since ESP-IDF build system doesn't support spaces yet..
After choosing any of the previous options, a status page is displayed showing ESP-IDF, tools and python environment setup progress status. When the setup is finished, a message is shown that "All settings have been configured. You can close this window."
NOTE: Check the troubleshooting section if you have any issue.
The user can manually configure the extension by setting the following configuration settings with corresponding values. Please take a look at Configuration settings for more information.
- With Visual Studio Code Command Palette (F1 or View Menu -> Command Palette) and type Preferences: Open Settings (JSON). This will open the user global settings for Visual Studio Code.
NOTE: The user could choose to modify its workspace settings.json for a workspace limited configuration or a project limited configuration in the project's
.vscode/settings.json
. Please take a look at Working with multiple projects. - Your settings.json should look like:
MacOS/Linux
{
"idf.espIdfPath": "path/to/esp-idf",
"idf.customExtraPaths": "UPDATED_PATH",
"idf.customExtraVars": {
"OPENOCD_SCRIPTS": "OPENOCD_FOLDER/share/openocd/scripts"
},
"idf.pythonBinPath": "PYTHON_INTERPRETER",
"idf.openOcdConfigs": [
"interface/ftdi/esp32_devkitj_v1.cfg",
"board/esp32-wrover.cfg"
],
"idf.port": "DEVICE_PORT"
}
Windows
{
"idf.espIdfPathWin": "path/to/esp-idf",
"idf.customExtraPaths": "UPDATED_PATH",
"idf.customExtraVars": {
"OPENOCD_SCRIPTS": "OPENOCD_FOLDER/share/openocd/scripts"
},
"idf.pythonBinPathWin": "PYTHON_INTERPRETER",
"idf.openOcdConfigs": [
"interface/ftdi/esp32_devkitj_v1.cfg",
"board/esp32-wrover.cfg"
],
"idf.portWin": "DEVICE_PORT"
}
where:
- UPDATED_PATH is the "Updated PATH variable" generated by
$IDF_PATH/export.sh
, - PYTHON_INTERPRETER is the "Using Python interpreter in" value generated by
$IDF_PATH/export.sh
, - DEVICE_PORT is your device serial port (i.e. COM1, /dev/cu.usbserial-1433401 or /dev/ttyUSB1)
idf.openOcdConfigs
are the config files used for OpenOCD for your device (relative paths toOPENOCD_SCRIPTS
directory of OpenOCD-ESP32 tool).
DO NOT USE ~,
NOTE: Make sure that your configurations settings doesn't have any spaces to avoid any build issues.
Make sure to install the extension and extension debug adapter Python requirements by running the following commands in your terminal:
PYTHON_INTERPRETER -m pip install --upgrade -r EXTENSION_PATH/requirements.txt
PYTHON_INTERPRETER -m pip install --upgrade -r EXTENSION_PATH/esp_debug_adapter/requirements.txt
where EXTENSION_PATH is
%USERPROFILE%\.vscode\extensions\espressif.esp-idf-extension-VERSION
on Windows$HOME/.vscode/extensions/espressif.esp-idf-extension-VERSION
on Linux/MacOS
This is the same as JSON Manual Configuration but the name of each configuration setting is the description given in the ESP-IDF Settings. This method also need to install extension and debug adapter requirements.txt as shown in the previous section.
An example ESP-IDF path is to set idf.espIdfPath
to /home/myUser/to/esp-idf
(MacOS/Linux) or set idf.espIdfPathWin
to C:\Users\myUser\esp\esp-idf
(Windows)
An example python path for idf.pythonBinPath
(MacOS/Linux) is
/home/myUser/.espressif/python_env/idf4.0_py3.5_env/bin/python
An example python path for idf.pythonBinPathWin
(Windows) is
C:\Users\myUser\.espressif\python_env\idf4.0_py3.5_env\Scripts\python.exe
For example if required ESP-IDF Tools are:
- OpenOCD executable path is
/home/myUser/.espressif/tools/openocd-esp32/version/openocd-esp32/bin/openocd
orC:\Users\myUser\.espressif\tools\openocd-esp32\version\openocd-esp32\bin\openocd
(Windows) - XtensaEsp32 executable path is
/home/myUser/.espressif/tools/xtensa-esp32/version/xtensa-esp32/bin/xtensa-esp32-gcc
orC:\Users\myUser\.espressif\tools\xtensa\version\xtensa-esp32\bin\xtensa-esp32-gcc
(Windows)
you need to set in idf.customExtraPaths
:
- Linux/MacOS
/home/myUser/.espressif/tools/openocd/version/openocd-esp32/bin:/home/myUser/.espressif/tools/xtensa-esp32/version/xtensa-esp32/bin
- Windows
C:\Users\myUser\.espressif\tools\openocd-esp32\version\openocd-esp32\bin;C:\Users\myUser\.espressif\tools\xtensa-esp32\version\xtensa-esp32\bin
idf.customExtraVars
is an JSON object saved in Visual Studio Code's settings.json (Make sure to replace ${TOOL_PATH} with the existing tool directory path):
"idf.customExtraVars": {
"OPENOCD_SCRIPTS":"/home/myUser/.espressif/tools/openocd-esp32/version/openocd-esp32/share/openocd/scripts"
}
The list of required ESP-IDF Tools (idf.customExtraPaths
) and environment variables (idf.customExtraVars
) can be found in $IDF_PATH/tools/tools.json
NOTE: Make sure to replace ${TOOL_PATH} of
$IDF_PATH/tools/tools.json
inidf.customExtraPaths
andidf.customExtraVars
with existing ESP-IDF tool directory path.
idf.openOcdConfigs
use openOCD Configuration files depending on your board and chip target. More information here.