Downloadable IDF Tools
The ESP-IDF build process relies on a number of tools: cross-compiler toolchains, CMake build system, and others.
Installing the tools using an OS-specific package manager (e.g., apt, yum, brew, etc.) is the preferred method, when the required version of the tool is available. This recommendation is reflected in the Get Started. For example, on Linux and macOS, it is recommended to install CMake using an OS package manager.
However, some of the tools are specific to ESP-IDF and are not available in OS package repositories. Furthermore, different ESP-IDF versions require different tool versions for proper operation. To solve these two problems, ESP-IDF provides a set of scripts that can download and install the correct tool versions and set up the environment accordingly.
The rest of the document refers to these downloadable tools simply as "tools". Other kinds of tools used in ESP-IDF are:
- Python scripts bundled with ESP-IDF such as - idf.py
- Python packages installed from PyPI 
The following sections explain the installation method and provide the list of tools installed on each platform.
Note
This document is provided for advanced users who need to customize their installation, users who wish to understand the installation process, and ESP-IDF developers.
If you are looking for instructions on how to install the tools, see Get Started.
Tools Metadata File
The list of tools and tool versions required for each platform is located in tools/tools.json. The schema of this file is defined by tools/tools_schema.json.
This file is used by the tools/idf_tools.py script when installing the tools or setting up the environment variables.
Tools Installation Directory
The IDF_TOOLS_PATH environment variable specifies the location where the tools are to be downloaded and installed. If not set, the default location will be HOME/.espressif on Linux and macOS, and %USER_PROFILE%\.espressif on Windows.
Inside the IDF_TOOLS_PATH directory, the tools installation scripts create the following directories and files:
- dist— where the archives of the tools are downloaded.
- tools— where the tools are extracted. The tools are extracted into subdirectories:- tools/TOOL_NAME/VERSION/. This arrangement allows different versions of tools to be installed side by side.
- idf-env.json— user install options, such as targets and features, are stored in this file. Targets are selected chip targets for which tools are installed and kept up-to-date. Features determine the Python package set which should be installed. These options will be discussed later.
- python_env— not related to the tools; virtual Python environments are installed in the sub-directories. Note that the Python environment directory can be placed elsewhere by setting the- IDF_PYTHON_ENV_PATHenvironment variable.
- espidf.constraints.*.txt— one constraint file for each ESP-IDF release containing Python package version requirements.
GitHub Assets Mirror
Most of the tools downloaded by the tools installer are GitHub Release Assets, which are files attached to a software release on GitHub.
If GitHub downloads are inaccessible or slow to access, a GitHub assets mirror can be configured.
To use Espressif's download server, set the environment variable IDF_GITHUB_ASSETS to dl.espressif.com/github_assets, or dl.espressif.cn/github_assets for faster download in China. When the install process is downloading a tool from github.com, the URL will be rewritten to use this server instead.
Any mirror server can be used provided the URL matches the github.com download URL format. For any GitHub asset URL that the install process downloads, it will replace https://github.com with https://${IDF_GITHUB_ASSETS}.
Note
The Espressif download server currently does not mirror everything from GitHub, but only files attached as Assets to some releases, as well as source archives for some releases.
idf_tools.py Script
The tools/idf_tools.py script bundled with ESP-IDF performs several functions:
- install: Download the tool into the- ${IDF_TOOLS_PATH}/distdirectory and extract it into- ${IDF_TOOLS_PATH}/tools/TOOL_NAME/VERSION.- The - installcommand accepts the list of tools to install in the- TOOL_NAMEor- TOOL_NAME@VERSIONformat. If- allis given, all the tools, including required and optional ones, are installed. If no argument or- requiredis given, only the required tools are installed.
- download: Similar to- installbut doesn't extract the tools. An optional- --platformargument may be used to download the tools for the specific platform.
- export: Lists the environment variables that need to be set to use the installed tools. For most of the tools, setting the- PATHenvironment variable is sufficient, but some tools require extra environment variables.- The environment variables can be listed in either - shellor- key-valueformats, which can be set using the- --formatparameter:- exportoptional parameters:- --unset: Creates a statement that unsets specific global variables and restores the environment to its state before calling- export.{sh/fish}.
- --add_paths_extras: Adds extra ESP-IDF-related paths of- $PATHto- ${IDF_TOOLS_PATH}/esp-idf.json, which is used to remove global variables when the active ESP-IDF environment is deactivated. For example, while processing the- export.{sh/fish}script, if new paths are added to the global variable- $PATH, this option saves these new paths to the- ${IDF_TOOLS_PATH}/esp-idf.jsonfile.
 
- shell: Produces output suitable for evaluation in the shell. For example, produce the following output on Linux and macOS:- export PATH="/home/user/.espressif/tools/tool/v1.0.0/bin:$PATH" - Produce the following output on Windows: - set "PATH=C:\Users\user\.espressif\tools\v1.0.0\bin;%PATH%" - Note - Exporting environment variables in Powershell format is not supported at the moment. - key-valueformat may be used instead.- The output of this command may be used to update the environment variables if the shell supports it. For example - eval $($IDF_PATH/tools/idf_tools.py export) 
- key-value: Produces output in the- VARIABLE=VALUEformat that is suitable for parsing by other scripts- PATH=/home/user/.espressif/tools/tool/v1.0.0:$PATH - Note that the script consuming this output has to perform expansion of - $VARor- %VAR%patterns found in the output.
 
- list: Lists the known versions of the tools, and indicates which ones are installed.- The following option is available to customize the output. - --outdated: Lists only outdated versions of tools installed in- IDF_TOOLS_PATH.
 
- check: For each tool, checks whether the tool is available in the system path and in- IDF_TOOLS_PATH.
- install-python-env: Creates a Python virtual environment in the- ${IDF_TOOLS_PATH}/python_envdirectory or directly in the directory set by the- IDF_PYTHON_ENV_PATHenvironment variable, and install the required Python packages there.- An optional - --featuresargument allows one to specify a comma-separated list of features to be added or removed.- A feature that begins with - -will be removed, and features with- +or without any sign will be added. Example syntax for removing feature- XYis- --features=-XY, and for adding feature- XYis- --features=+XYor- --features=XY. If both removing and adding options are provided with the same feature, no operation is performed.
- For each feature, a requirements file must exist. For example, feature - XYis a valid feature if- ${IDF_PATH}/tools/requirements/requirements.XY.txtis an existing file with a list of Python packages to be installed.
- There is one mandatory - corefeature ensuring the core functionality of ESP-IDF, e.g., build, flash, monitor, debug in console. There can be an arbitrary number of optional features.
- The selected list of features is stored in - idf-env.json.
- The requirement files contain a list of the desired Python packages to be installed and the - espidf.constraints.*.txtfile downloaded from https://dl.espressif.com and stored in- ${IDF_TOOLS_PATH}, which contains the package version requirements for a given ESP-IDF version.
 
 - Note - Although it is not recommended, the download and use of constraint files can be disabled with the - --no-constraintsargument or setting the- IDF_PYTHON_CHECK_CONSTRAINTSenvironment variable to- no.
- check-python-dependencies: Checks if all required Python packages are installed. Packages from- ${IDF_PATH}/tools/requirements/requirements.*.txtfiles selected by the feature list of- idf-env.jsonare checked with the package versions specified in the- espidf.constraints.*.txtfile.- Note - The constraint file is downloaded with the - install-python-envcommand. Similar to the- install-python-envcommand, the use of constraint files can be disabled with the- --no-constraintsargument or setting the- IDF_PYTHON_CHECK_CONSTRAINTSenvironment variable to- no.
- uninstall: Prints and removes tools that are currently not used by the active ESP-IDF version.- --dry-run: Prints installed unused tools.
- --remove-archives: Additionally removes all older versions of previously downloaded installation packages.
 
Install Scripts
Shell-specific user-facing installation scripts are provided in the root directory of ESP-IDF repository to facilitate tools installation. These are:
- install.batfor Windows Command Prompt
- install.ps1for Powershell
- install.shfor Bash
- install.fishfor Fish
Apart from downloading and installing the tools in IDF_TOOLS_PATH, these scripts prepare a Python virtual environment, and install the required packages into that environment.
These scripts accept optionally a comma-separated list of chip targets and --enable-* arguments for enabling features. These arguments are passed to the idf_tools.py script which stores them in idf-env.json. Therefore, chip targets and features can be enabled incrementally.
To install tools for all chip targets, run the scripts without any optional arguments using idf_tools.py install --targets=all. Similarly, to install Python packages for core ESP-IDF functionality, run idf_tools.py install-python-env --features=core.
It is also possible to install tools for specific chip targets. For example, install.sh esp32 installs tools only for ESP32. See Step 3. Set up the Tools for more examples.
install.sh --enable-XY enables feature XY (by running idf_tools.py install-python-env --features=core,XY).
Export Scripts
Since the installed tools are not permanently added to the user or system PATH environment variable, an extra step is required to use them in the command line. The following scripts modify the environment variables in the current shell to make the correct versions of the tools available:
- export.batfor Windows Command Prompt
- export.ps1for Powershell
- export.shfor Bash
- export.fishfor Fish
Note
To modify the shell environment in Bash, export.sh must be "sourced" by using the . ./export.sh command. Please ensure to include the leading dot and space.
export.sh may be used with shells other than Bash (such as zsh). However, in this case, it is required to set the IDF_PATH environment variable before running the script. When used in Bash, the script guesses the IDF_PATH value from its own location.
In addition to calling idf_tools.py, these scripts list the directories that have been added to the PATH.
Other Installation Methods
Depending on the environment, more user-friendly wrappers for idf_tools.py are provided:
- ESP-IDF Tools Installer can download and install the tools. Internally the installer uses - idf_tools.py.
- ESP-IDF Eclipse Plugin includes a menu item to set up the tools. Internally the plugin calls - idf_tools.py.
- VSCode ESP-IDF Extension includes an onboarding flow. This flow helps set up the tools. Although the extension does not rely on - idf_tools.py, the same installation method is used.
Custom Installation
Although the methods above are recommended for ESP-IDF users, they are not a must for building ESP-IDF applications. ESP-IDF build system expects that all the necessary tools are installed somewhere, and made available in the PATH.
Uninstall ESP-IDF
Uninstalling ESP-IDF requires removing both the tools and the environment variables that have been configured during the installation.
- Windows users using the Windows ESP-IDF Tools Installer can simply run the uninstall wizard to remove ESP-IDF. 
- To remove an installation performed by running the supported install scripts, simply delete the tools installation directory including the downloaded and installed tools. Any environment variables set by the export scripts are not permanent and will not be present after opening a new environment. 
- When dealing with a custom installation, in addition to deleting the tools as mentioned above, you may also need to manually revert any changes to environment variables or system paths that were made to accommodate the ESP-IDF tools (e.g., - IDF_PYTHON_ENV_PATHor- IDF_TOOLS_PATH). If you manually copied any tools, you would need to track and delete those files manually.
- If you installed any plugins like the ESP-IDF Eclipse Plugin or VSCode ESP-IDF Extension, you should follow the specific uninstallation instructions described in the documentation of those components. 
Note
Uninstalling the ESP-IDF tools does not remove any project files or your code. Be mindful of what you are deleting to avoid losing any work. If you are unsure about a step, refer back to the installation instructions.
These instructions assume that the tools were installed following the procedures in this provided document. If you've used a custom installation method, you might need to adapt these instructions accordingly.
List of ESP-IDF Tools
xtensa-esp-elf-gdb
GDB for Xtensa
License: GPL-3.0-or-later
More info: https://github.com/espressif/binutils-gdb
| Platform | Required | Download | 
|---|---|---|
| linux-amd64 | required | SHA256: 9d68472d4cba5cf8c2b79d94f86f92c828e76a632bd1e6be5e7706e5b304d36e | 
| linux-arm64 | required | SHA256: bdabc3217994815fc311c4e16e588b78f6596b5ad4ffa46c80b40e982cfb1e66 | 
| linux-armel | required | SHA256: d54b8d703ba897b28c627da3d27106a3906dd01ba298778a67064710bc33c76d | 
| linux-armhf | required | SHA256: 6187d1dd54e57927f7a7b804ff431fe0a295d5d5638c7654ee2bb7c3e0e84d4b | 
| linux-i686 | required | SHA256: 64d3bc992ed8fdec383d49e8b803ac494605a38117c8293db8da055037de96b0 | 
| macos | required | SHA256: 023e74b3fda793da4bc0509b02de776ee0dad6efaaac17bef5916fb7dc9c26b9 | 
| macos-arm64 | required | SHA256: ea757c6bf8c25238f6d2fdcc6bbab25a1b00608a0f9e19b7ddd2f37ddbdc3fb1 | 
| win32 | required | SHA256: 322e8d9b700dc32d8158e3dc55fb85ec55de48d0bb7789375ee39a28d5d655e2 | 
| win64 | required | SHA256: a27a2fe20f192f8e0a51b8936428b4e1cf8935cfe008ee445cc49f6fc7f6db2e | 
riscv32-esp-elf-gdb
GDB for RISC-V
License: GPL-3.0-or-later
More info: https://github.com/espressif/binutils-gdb
| Platform | Required | Download | 
|---|---|---|
| linux-amd64 | required | SHA256: ce004bc0bbd71b246800d2d13b239218b272a38bd528e316f21f1af2db8a4b13 | 
| linux-arm64 | required | SHA256: ba10f2866c61410b88c65957274280b1a62e3bed05131654ed9b6758efe18e55 | 
| linux-armel | required | SHA256: 88539db5d987f28827efac7e26080a2803b9b539342ccd2963ccfdd56d7f08f7 | 
| linux-armhf | required | SHA256: b45b9711d6a87d4c2f688a9599ce850ce02f477756e3e797c4a6c1c549127fcb | 
| linux-i686 | required | SHA256: 0e628ee37438ab6ba05eb889a76d09e50cb98e0020a16b8e2b935c5cf19b4ed2 | 
| macos | required | SHA256: 8f6bda832d70dad5860a639d55aba4237bd10cbac9f4822db1eece97357b34a9 | 
| macos-arm64 | required | SHA256: d88b6116e86456c8480ce9bc95aed375a35c0d091f1da0a53b86be0e6ef3d320 | 
| win32 | required | SHA256: d6e7ce05805b0d8d4dd138ad239b98a1adf8da98941867d60760eb1ae5361730 | 
| win64 | required | SHA256: 5c9f211dc46daf6b96fad09d709284a0f0186fef8947d9f6edd6bca5b5ad4317 | 
xtensa-esp-elf
Toolchain for 32-bit Xtensa based on GCC
License: GPL-3.0-with-GCC-exception
More info: https://github.com/espressif/crosstool-NG
| Platform | Required | Download | 
|---|---|---|
| linux-amd64 | required | SHA256: bae7da23ea8516fb7e42640f4420c4dd1ebfd64189a14fc330d73e173b3a038b | 
| linux-arm64 | required | SHA256: faa4755bedafb1c10feaeef01c610803ee9ace088b26d7db90a5ee0816c20f9e | 
| linux-armel | required | SHA256: 38702870453b8d226fbc348ae2288f02cbc6317a3afa89982da6a6ef6866e05a | 
| linux-armhf | required | SHA256: aeb872fe0f7f342ed1a42e02dad15e1fa255aec852e88bb8ff2725380ddde501 | 
| linux-i686 | required | SHA256: fc25701749f365af5f270221e0e8439ce7fcc26eeac145a91cfe02f3100de2d6 | 
| macos | required | SHA256: b9b7a6d1dc4ea065bf6763fa904729e1c808d6dfbf1dfabf12852e2929251ee9 | 
| macos-arm64 | required | SHA256: 687243e5cbefb7cf05603effbdd6fde5769f94daff7e519f5bbe61f43c4c0ef6 | 
| win32 | required | SHA256: 7a2822ef554be175bbe5c67c2010a6dd29aec6221bdb5ed8970f164e2744714a | 
| win64 | required | SHA256: 80e3271b7c9b64694ba8494b90054da2efce328f7d4e5f5f625d08808372fa64 | 
esp-clang
Toolchain for all Espressif chips based on clang
License: Apache-2.0
More info: https://github.com/espressif/llvm-project
| Platform | Required | Download | 
|---|---|---|
| linux-amd64 | optional | SHA256: 3dbd8dd290913a93e8941da8a451ecd49f9798cc2d74bb9b63ef5cf5c4fee37f | 
| linux-arm64 | optional | SHA256: 4b115af6ddd04a9bffc1908fc05837998ee71d450891d741c446186f2aa9b961 | 
| linux-armhf | optional | SHA256: 935082bb0704420c5ca42b35038bba8702135348a50cac454ae2fb55af0b4c32 | 
| macos | optional | SHA256: d9824acafd3e7b1d17ace084243b82a95bbdcb149a26b085bba487ab3d3716d7 | 
| macos-arm64 | optional | SHA256: ed5621396dc3e48413e14e8b6caed8e2993e7f2ab5fca1410081f40c940a1060 | 
| win64 | optional | SHA256: 598c8241c8bf10fd1be8bd21845307cfc404e127041b4ba4e828350a88692883 | 
riscv32-esp-elf
Toolchain for 32-bit RISC-V based on GCC
License: GPL-3.0-with-GCC-exception
More info: https://github.com/espressif/crosstool-NG
| Platform | Required | Download | 
|---|---|---|
| linux-amd64 | required | SHA256: 782feefe354500c5f968e8c91959651be3bdbbd7ae8a17affcee2b1bffcaad89 | 
| linux-arm64 | required | SHA256: 6ee4b30dff18bdea9ada79399c0c81ba82b6ed99a565746a7d5040c7e62566b3 | 
| linux-armel | required | SHA256: 3231ca04ea4f53dc602ae1cc728151a16c5d424063ac69542b8bf6cde10e7755 | 
| linux-armhf | required | SHA256: eb43ac9dcad8fe79bdf4b8d29cf4751d41cbcb1fadd831f2779a84f4fb1c5ca0 | 
| linux-i686 | required | SHA256: 51421bd181392472fee8242d53dfa6305a67b21e1073f0f9f69d215987da9684 | 
| macos | required | SHA256: ce40c75a1ae0e4b986daeeff321aaa7b57f74eb4bcfd011f1252fd6932bbb90f | 
| macos-arm64 | required | SHA256: c2f989370c101ae3f890aa71e6f57064f068f7c4a1d9f26445894c83f919624f | 
| win32 | required | SHA256: 37737463826486c9c11e74a140b1b50195dc868e547c8ee557950c811741197c | 
| win64 | required | SHA256: 1300a54505dc964fa9104482737152e669f4d880efc1d54057378d9e6910ae1e | 
esp32ulp-elf
Toolchain for ESP32 ULP coprocessor
License: GPL-3.0-or-later
More info: https://github.com/espressif/binutils-gdb
| Platform | Required | Download | 
|---|---|---|
| linux-amd64 | required | SHA256: b1f7801c3a16162e72393ebb772c0cbfe4d22d907be7c2c2dac168736e9195fd | 
| linux-arm64 | required | SHA256: d6671b31bab31b9b13aea25bb7d60f15484cb8bf961ddbf67a62867e5563eae5 | 
| linux-armel | required | SHA256: e107e7a9cd50d630b034f435a16a52db5a57388dc639a99c4c393c5e429711e9 | 
| linux-armhf | required | SHA256: 6c6dd25477b2e758d4669da3774bf664d1f012442c880f17dfdf0339e9c3dae9 | 
| linux-i686 | required | SHA256: beb9b6737c975369b6959007739c88f44eb5afbb220f40737071540b2c1a9064 | 
| macos | required | SHA256: 5a952087b621ced16af1e375feac1371a61cb51ab7e7b44cbefb5afda2d573de | 
| macos-arm64 | required | SHA256: 73bda8476ef92d4f4abee96519abbba40e5ee32f368427469447b83cc7bb9b42 | 
| win32 | required | SHA256: 77344715ea7d7a7a9fd0b27653f880efaf3bcc1ac843f61492d8a0365d91f731 | 
| win64 | required | SHA256: 525e5b4c8299869a3fdddb51baad76612c5c104bd96952ae6460ad7e5b5a4e21 | 
cmake
CMake build system
On Linux and macOS, it is recommended to install CMake using the OS-specific package manager (like apt, yum, brew, etc.). However, for convenience it is possible to install CMake using idf_tools.py along with the other tools.
License: BSD-3-Clause
More info: https://github.com/Kitware/CMake
| Platform | Required | Download | 
|---|---|---|
| linux-amd64 | optional | https://github.com/Kitware/CMake/releases/download/v3.24.0/cmake-3.24.0-linux-x86_64.tar.gz SHA256: 726f88e6598523911e4bce9b059dc20b851aa77f97e4cc5573f4e42775a5c16f | 
| linux-arm64 | optional | https://github.com/Kitware/CMake/releases/download/v3.24.0/cmake-3.24.0-linux-aarch64.tar.gz SHA256: 50c3b8e9d3a3cde850dd1ea143df9d1ae546cbc5e74dc6d223eefc1979189651 | 
| linux-armel | optional | https://dl.espressif.com/dl/cmake/cmake-3.24.0-Linux-armv7l.tar.gz SHA256: 7dc787ef968dfef92491a4f191b8739ff70f8a649608b811c7a737b52481beb0 | 
| linux-armhf | optional | https://dl.espressif.com/dl/cmake/cmake-3.24.0-Linux-armv7l.tar.gz SHA256: 7dc787ef968dfef92491a4f191b8739ff70f8a649608b811c7a737b52481beb0 | 
| macos | optional | https://github.com/Kitware/CMake/releases/download/v3.24.0/cmake-3.24.0-macos-universal.tar.gz SHA256: 3e0cca74a56d9027dabb845a5a26e42ef8e8b33beb1655d6a724187a345145e4 | 
| macos-arm64 | optional | https://github.com/Kitware/CMake/releases/download/v3.24.0/cmake-3.24.0-macos-universal.tar.gz SHA256: 3e0cca74a56d9027dabb845a5a26e42ef8e8b33beb1655d6a724187a345145e4 | 
| win32 | required | https://github.com/Kitware/CMake/releases/download/v3.24.0/cmake-3.24.0-windows-x86_64.zip SHA256: b1ad8c2dbf0778e3efcc9fd61cd4a962e5c1af40aabdebee3d5074bcff2e103c | 
| win64 | required | https://github.com/Kitware/CMake/releases/download/v3.24.0/cmake-3.24.0-windows-x86_64.zip SHA256: b1ad8c2dbf0778e3efcc9fd61cd4a962e5c1af40aabdebee3d5074bcff2e103c | 
openocd-esp32
OpenOCD for ESP32
License: GPL-2.0-only
More info: https://github.com/espressif/openocd-esp32
| Platform | Required | Download | 
|---|---|---|
| linux-amd64 | required | SHA256: f8c68541fa38307bc0c0763b7e1e3fe4e943d5d45da07d817a73b492e103b652 | 
| linux-arm64 | required | SHA256: 4d6e263d84e447354dc685848557d6c284dda7fe007ee451f729a7edfa7baad7 | 
| linux-armel | required | SHA256: 9d45679f2c4cf450d5e2350047cf57bb76dde2487d30cebce0a72c9173b5c45b | 
| linux-armhf | required | SHA256: 7f56d6a0c73e3988891a0781adee4973e6b9ea4bb4584cacb88384cb3db59050 | 
| macos | required | SHA256: 565c8fabc5f19a6e7a0864a294d74b307eec30b9291d16d3fc90e273f0330cb4 | 
| macos-arm64 | required | SHA256: 68c5c7cf3d15b9810939a5edabc6ff2c9f4fc32262de91fc292a180bc5cc0637 | 
| win32 | required | SHA256: 463fc2903ddaf03f86ff50836c5c63cc696550b0446140159eddfd2e85570c5d | 
| win64 | required | SHA256: 550f57369f1f1f6cc600b5dffa3378fd6164d8ea8db7c567cf41091771f090cb | 
ninja
Ninja build system
On Linux and macOS, it is recommended to install ninja using the OS-specific package manager (like apt, yum, brew, etc.). However, for convenience it is possible to install ninja using idf_tools.py along with the other tools.
License: Apache-2.0
More info: https://github.com/ninja-build/ninja
| Platform | Required | Download | 
|---|---|---|
| linux-amd64 | optional | https://github.com/ninja-build/ninja/releases/download/v1.11.1/ninja-linux.zip SHA256: b901ba96e486dce377f9a070ed4ef3f79deb45f4ffe2938f8e7ddc69cfb3df77 | 
| macos | optional | https://github.com/ninja-build/ninja/releases/download/v1.11.1/ninja-mac.zip SHA256: 482ecb23c59ae3d4f158029112de172dd96bb0e97549c4b1ca32d8fad11f873e | 
| macos-arm64 | optional | https://github.com/ninja-build/ninja/releases/download/v1.11.1/ninja-mac.zip SHA256: 482ecb23c59ae3d4f158029112de172dd96bb0e97549c4b1ca32d8fad11f873e | 
| win64 | required | https://github.com/ninja-build/ninja/releases/download/v1.11.1/ninja-win.zip SHA256: 524b344a1a9a55005eaf868d991e090ab8ce07fa109f1820d40e74642e289abc | 
idf-exe
IDF wrapper tool for Windows
License: Apache-2.0
More info: https://github.com/espressif/idf_py_exe_tool
| Platform | Required | Download | 
|---|---|---|
| win32 | required | https://github.com/espressif/idf_py_exe_tool/releases/download/v1.0.3/idf-exe-v1.0.3.zip SHA256: 7c81ef534c562354a5402ab6b90a6eb1cc8473a9f4a7b7a7f93ebbd23b4a2755 | 
| win64 | required | https://github.com/espressif/idf_py_exe_tool/releases/download/v1.0.3/idf-exe-v1.0.3.zip SHA256: 7c81ef534c562354a5402ab6b90a6eb1cc8473a9f4a7b7a7f93ebbd23b4a2755 | 
ccache
Ccache (compiler cache)
License: GPL-3.0-or-later
More info: https://github.com/ccache/ccache
| Platform | Required | Download | 
|---|---|---|
| win64 | required | https://github.com/ccache/ccache/releases/download/v4.8/ccache-4.8-windows-x86_64.zip SHA256: a2b3bab4bb8318ffc5b3e4074dc25636258bc7e4b51261f7d9bef8127fda8309 | 
dfu-util
dfu-util (Device Firmware Upgrade Utilities)
License: GPL-2.0-only
More info: http://dfu-util.sourceforge.net/
| Platform | Required | Download | 
|---|---|---|
| win64 | required | https://dl.espressif.com/dl/dfu-util-0.11-win64.zip SHA256: 652eb94cb1c074c6dbead9e47adb628922aeb198a4d440a346ab32e7a0e9bf64 | 
esp-rom-elfs
ESP ROM ELFs
License: Apache-2.0
More info: https://github.com/espressif/esp-rom-elfs
| Platform | Required | Download | 
|---|---|---|
| any | required | https://github.com/espressif/esp-rom-elfs/releases/download/20230320/esp-rom-elfs-20230320.tar.gz SHA256: 24bcc8cb3287175d4a0bfd65e04bf7ef592a10f022acffca0d5e87eee05996d4 | 
qemu-xtensa
QEMU for Xtensa
Some ESP-specific instructions for running QEMU for Xtensa chips are here: https://github.com/espressif/esp-toolchain-docs/blob/main/qemu/esp32/README.md
License: GPL-2.0-only
More info: https://github.com/espressif/qemu
| Platform | Required | Download | 
|---|---|---|
| linux-amd64 | optional | SHA256: 071d117c44a6e9a1bc8664ab63b592d3e17ceb779119dcb46c59571a4a7a88c9 | 
| linux-arm64 | optional | SHA256: 43552f32b303a6820d0d9551903e54fc221aca98ccbd04e5cbccbca881548008 | 
| macos | optional | SHA256: 0096734280ce04f558cd9bd72f35db39667f80d44309a35565f2f8c02d1f9cc3 | 
| macos-arm64 | optional | SHA256: fb4ca6be7b1a4dbcf153879cf0582300f974371def0826c0c5b728f12812ad08 | 
| win64 | optional | SHA256: 281659f7a1d49761ac6f54d0aeb14366cb93c002f21948b847a0e15c0b8f5425 | 
qemu-riscv32
QEMU for RISC-V
Some ESP-specific instructions for running QEMU for RISC-V chips are here: https://github.com/espressif/esp-toolchain-docs/blob/main/qemu/esp32c3/README.md
License: GPL-2.0-only
More info: https://github.com/espressif/qemu
| Platform | Required | Download | 
|---|---|---|
| linux-amd64 | optional | SHA256: 47120e826cfec7180db8cb611a7a4aed2e9b2191c2a739194f8ce085e63cdd8d | 
| linux-arm64 | optional | SHA256: 3b6221a8b1881d2c9b9fa0b0bf8d7065c84153d2a54e429307bde9feae235c27 | 
| macos | optional | SHA256: 3afa55d5abea52ccf18d0bc41fe819d568bd4ee1582989b1ee9b1ee4a609a31e | 
| macos-arm64 | optional | SHA256: 69ba5154594fb2922d5490a49ea6b4925c024c6c37f875b42f9885f513e0bcdd | 
| win64 | optional | SHA256: f49bb5c8f4d6e2cfbf7eeec21eb8ef190a57307778705bc689536ac13bde511c |