可下载的 ESP-IDF 工具
构建过程中,ESP-IDF 依赖许多工具,如交叉编译工具链、CMake 构建系统等。
如 快速入门 所述,若所需工具版本可用,首选使用当前操作系统的软件包管理器(如 apt、yum、brew 等)安装相关工具。例如,在 Linux 和 macOS 系统中,建议用 Linux 和 macOS 系统的软件包管理器安装 CMake。
但部分 ESP-IDF 的特定工具在操作系统软件包存储库中不可用,且不同版本的 ESP-IDF 需相应使用不同版本的工具运行。为解决以上两个问题,ESP-IDF 提供了一组脚本,可以下载和安装正确的工具版本,并设置相应运行环境。
下文中,这类可下载的工具简称为“工具”。除此类工具外,ESP-IDF 还使用以下工具:
ESP-IDF 捆绑的 Python 脚本,如
idf.py
从 PyPI 安装的 Python 软件包
以下各小节介绍了可下载工具的安装方法,并提供了在不同平台上安装的工具列表。
工具元数据文件
各平台所需工具及工具版本列表存放在 tools/tools.json 文件中,tools/tools_schema.json 定义了该文件的模式。
在安装工具或设置环境变量时,tools/idf_tools.py 脚本将使用上述文件。
工具安装目录
IDF_TOOLS_PATH
环境变量指定下载及安装工具的位置。若未设置该变量,Linux 和 macOS 系统的默认下载安装位置为 HOME/.espressif
,Windows 系统的默认下载安装位置为 %USER_PROFILE%\.espressif
。
在 IDF_TOOLS_PATH
目录下,工具安装脚本会创建以下子目录和文件:
dist
— 工具存档下载位置。tools
— 工具解压缩位置。工具会解压缩到子目录tools/TOOL_NAME/VERSION/
中,该操作支持同时安装不同版本的工具。idf-env.json
— “目标 (target)”和“功能 (feature)”等用户安装选项均存储在此文件中。“目标”为选择需要安装和保持更新的工具的芯片目标;“功能”则决定应安装哪些 Python 软件包。有关用户安装选项的详情,请参阅下文。python_env
— 与工具无关;虚拟 Python 环境安装在其子目录中。注意,设置IDF_PYTHON_ENV_PATH
环境变量可以将 Python 环境目录放置到其他位置。espidf.constraints.*.txt
— 每个 ESP-IDF 版本都有的约束文件,包含 Python 包版本要求。
GitHub 资源镜像
工具下载器下载的工具大多属于 GitHub 发布的资源,即在 GitHub 上伴随软件发布的文件。
如果无法访问 GitHub 下载或访问速度较慢,可以配置一个 GitHub 资源镜像。
要使用乐鑫下载服务器,请将环境变量 IDF_GITHUB_ASSETS
设置为 dl.espressif.com/github_assets
,在国内下载时,也可设置为 dl.espressif.cn/github_assets
加快下载速度。安装过程中,当从 github.com
下载工具时,URL 将重写为使用乐鑫下载服务器。
只要 URL 与 github.com
的下载 URL 格式匹配,任何镜像服务器均可使用,安装过程中下载的 GitHub 资源 URL 将把 https://github.com
替换为 https://${IDF_GITHUB_ASSETS}
。
备注
目前,乐鑫下载服务器不会镜像 GitHub 上的所有内容,只镜像部分发布版本的附件资源文件及源文件。
idf_tools.py
脚本
ESP-IDF 随附的 tools/idf_tools.py 脚本具备以下功能:
install
:将工具下载到${IDF_TOOLS_PATH}/dist
目录,并解压缩到${IDF_TOOLS_PATH}/tools/TOOL_NAME/VERSION
。install
命令接收TOOL_NAME
或TOOL_NAME@VERSION
格式的安装工具列表。如果给定参数all
,则会安装列表上的所有工具,包括必须项和可选项。如果没有给定参数,或给定参数为required
,则只安装必须项。download
:与install
类似,但不会解压缩工具。使用可选项--platform
可下载特定平台的工具。export
:列出使用已安装工具前应设置的环境变量。对多数工具而言,只需要设置环境变量PATH
,但也有些工具需要设置额外的环境变量。环境变量可以以
shell
或key-value
格式列出,使用--format
参数设置该选项。export
可选参数:--unset
:该参数可用于创建语句,取消特定全局变量设置,使环境恢复到调用export.{sh/fish}
前的状态。--add_paths_extras
:该参数将$PATH
中与 ESP-IDF 相关的额外路径添加到${IDF_TOOLS_PATH}/esp-idf.json
中,以保证在退出当前 ESP-IDF 环境时删除全局变量。例如,在运行export.{sh/fish}
脚本时,如果在全局变量$PATH
中添加了新的路径,在命令中添加该参数可以将这些新路径保存到${IDF_TOOLS_PATH}/esp-idf.json
文件中。
shell
:生成适合在 shell 中执行的输出,例如,在 Linux 和 macOS 上生成以下输出export PATH="/home/user/.espressif/tools/tool/v1.0.0/bin:$PATH"
在 Windows 上生成以下输出
set "PATH=C:\Users\user\.espressif\tools\v1.0.0\bin;%PATH%"
备注
当前不支持以 Powershell 格式导出环境变量,可以用
key-value
格式代替。如果 shell 支持,则该命令的输出可用于更新环境变量。例如
eval $($IDF_PATH/tools/idf_tools.py export)
key-value
:以VARIABLE=VALUE
格式生成输出,以便其他脚本解析PATH=/home/user/.espressif/tools/tool/v1.0.0:$PATH
注意,用于处理此输出的脚本必须对输出中的
$VAR
或%VAR%
模式进行扩展,即解析成对应变量。
list
:列出已知的工具版本,并指示哪些版本已安装。以下选项可用于自定义输出。
--outdated
:仅列出安装在IDF_TOOLS_PATH
中的过时版本工具。
check
:检查每个工具是否在系统路径和IDF_TOOLS_PATH
中可用。install-python-env
:在${IDF_TOOLS_PATH}/python_env
目录或直接在IDF_PYTHON_ENV_PATH
环境变量设置的目录中创建 Python 虚拟环境,并在其中安装所需的 Python 软件包。参数
--features
为可选项,用于指定要添加或删除的功能列表,功能之间用逗号分隔。该参数将删除以
-
开头的功能,添加以+
开头或无符号标记的功能。例如,要删除功能XY
,示例语法为--features=-XY
;要添加功能XY
,示例语法为--features=+XY
或--features=XY
。如果为同一功能同时提供了删除和添加选项,则不执行任何操作。每个功能都必须有依赖文件。例如,只有当
${IDF_PATH}/tools/requirements/requirements.XY.txt
文件已存在,并包含要安装的 Python 包列表时,功能XY
才有效。core
功能为必须项,确保 ESP-IDF 的核心功能,如控制台中的构建、烧录、监视器、调试等。用户可选择任意数量的可选功能,已选功能列表存储在
idf-env.json
中。依赖文件中存储了需要安装的 Python 包以及
espidf.constraints.*.txt
文件,该约束文件从 https://dl.espressif.com 下载,并存储在${IDF_TOOLS_PATH}
目录,包含了针对特定 ESP-IDF 版本的安装包版本要求。
备注
可以通过使用
--no-constraints
参数或将环境变量IDF_PYTHON_CHECK_CONSTRAINTS
设置为no
,禁用约束文件的下载和使用,但 并不建议此做法。check-python-dependencies
:检查所有必需的 Python 包是否均已安装。该命令会对比检查由idf-env.json
功能列表从${IDF_PATH}/tools/requirements/requirements.*.txt
所选择的软件包与espidf.constraints.*.txt
文件指定的软件包版本是否一致。备注
约束文件可通过
install-python-env
命令下载。与install-python-env
命令类似,可以通过使用--no-constraints
参数或将环境变量IDF_PYTHON_CHECK_CONSTRAINTS
设置为no
,禁止使用约束文件。uninstall
:打印并删除当前 ESP-IDF 版本未使用的工具。--dry-run
打印已安装但未使用的工具。--remove-archives
删除过去下载的所有旧版本软件安装包。
安装脚本
ESP-IDF 的根目录中提供了针对不同 shell 的用户安装脚本,包括:
install.bat
适用于 Windows 命令提示符install.ps1
适用于 Powershellinstall.sh
适用于 Bashinstall.fish
适用于 Fish
这些脚本除了下载和安装 IDF_TOOLS_PATH
中的工具外,还会准备一个 Python 虚拟环境,并在此虚拟环境中安装所需软件包。
为启用相应功能,这些脚本可以选择性地接受一组以逗号分隔的芯片目标列表及 --enable-*
参数,这类参数会传递给 idf_tools.py
脚本,并由该脚本将这类参数存储在 idf-env.json
中,从而逐步启用芯片目标及功能。
要为所有芯片目标安装工具,请在不使用任何可选参数的情况下,运行 idf_tools.py install --targets=all
。要安装具备 ESP-IDF 核心功能的 Python 软件包,请运行 idf_tools.py install-python-env --features=core
。
也可为特定芯片安装工具,例如,运行 install.sh esp32
可以只为 ESP32 安装工具。更多相关示例,请参阅 第三步:设置工具。
运行 idf_tools.py install-python-env --features=core,XY
,install.sh --enable-XY
可以启用 XY
功能。
导出脚本
由于安装好的工具并非永久添加到用户或系统的 PATH
环境变量中,因此,要在命令行中使用这些工具,还需要额外步骤。以下脚本会修改当前 shell 的环境变量,从而使用正确版本的工具:
export.bat
适用于 Windows 命令提示符export.ps1
适用于 Powershellexport.sh
适用于 Bashexport.fish
适用于 Fish
备注
在 Bash 中修改 shell 环境时,必须使用 . ./export.sh
命令加载 export.sh
,注意添加前面的点和空格。
export.sh
可以在除了 Bash 外的其他 shell(如 zsh)中使用。但在这种情况下,必须在运行脚本前设置 IDF_PATH
环境变量。在 Bash 中使用时,脚本会从当前目录猜测 IDF_PATH
的值。
除了调用 idf_tools.py
,这些脚本还会列出已经添加到 PATH
的目录。
其他安装方法
为适用于不同环境,ESP-IDF 提供了更多用户友好的 idf_tools.py
包装工具:
ESP-IDF 工具安装器 支持下载和安装工具,其内部使用
idf_tools.py
实现功能。ESP-IDF Eclipse 插件 包括了一个用于设置工具的菜单项,该插件内部调用
idf_tools.py
。VSCode ESP-IDF 扩展 提供了设置工具的入门流程。尽管此扩展包不依赖
idf_tools.py
,但安装方法相同。
自定义安装
推荐用户使用上述方法安装 ESP-IDF 工具,但也可以选择其他方式来构建 ESP-IDF 应用程序。自定义安装时,用户需将所有必要的工具都安装在某个位置,并在 PATH
中定义,以保证 ESP-IDF 构建系统可用。
卸载 ESP-IDF
卸载 ESP-IDF 需要删除安装过程中配置的工具和环境变量。
使用 Windows ESP-IDF 工具安装器 的 Windows 用户可以直接运行卸载向导卸载 ESP-IDF。
工具安装目录 下包含了已下载及安装的工具,删除该目录即可删除此前通过运行 安装脚本 安装的内容。通过 导出脚本 设置的环境变量不具备永久性,新环境中不会存在此类环境变量。
如在安装过程中进行了自定义设置,除删除上述工具外,可能还涉及手动恢复此前为适用 ESP-IDF 工具而修改的环境变量及系统路径,例如
IDF_PYTHON_ENV_PATH
或IDF_TOOLS_PATH
。如存在通过手动复制安装的工具,则也需手动追踪并删除相关文件。如安装了 ESP-IDF Eclipse 或 VSCode ESP-IDF 扩展程序 等插件,则需按照对应插件文档中的特定卸载说明进行操作。
备注
卸载 ESP-IDF 工具不会删除任何项目文件或用户代码。为防止意外丢失其他文件,请在删除文件时谨慎操作。如果对某个步骤的操作有所疑问,请参考前述安装说明。
上述卸载指南默认需卸载的工具是按本文档中的步骤进行安装的。如果使用了自定义安装,可能需要进行相应调整。
ESP-IDF 工具列表
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 |