rustup
for esp-rs
espup
is a tool for installing and maintaining the required toolchains for
developing applications in Rust for Espressif SoC's.
To better understand what espup
installs, see Rust on ESP targets
chapter of The Rust on ESP Book
Before running or installing espup
, make sure that the following dependencies are installed.
sh
sudo apt-get install -y git python3 python3-pip gcc build-essential curl pkg-config libudev-dev
libudev-dev
is only required when installing cargo-espflash
.python3
and python3-pip
are only required when installing ESP-IDF.sh
sudo dnf -y install git python3 python3-pip perl gcc systemd-devel
systemd-devel
is only required when installing cargo-espflash
.python3
and python3-pip
are only required when installing ESP-IDF.perl
is required to build openssl-sys
sudo zypper install -y git gcc libudev-devel ninja python3 python3-pip make
libudev-devel
is only required when installing cargo-espflash
.python3
and python3-pip
are only required when installing ESP-IDF.sh
cargo install espup
It's also possible to use cargo-binstall or to directly download the pre-compiled release binaries:
- Linux aarch64
sh
curl -L https://github.com/esp-rs/espup/releases/latest/download/espup-aarch64-unknown-linux-gnu -o espup
chmod a+x espup
- Linux x8664
sh
curl -L https://github.com/esp-rs/espup/releases/latest/download/espup-x86_64-unknown-linux-gnu -o espup
chmod a+x espup
- macOS aarch64
sh
curl -L https://github.com/esp-rs/espup/releases/latest/download/espup-aarch64-apple-darwin -o espup
chmod a+x espup
- macOS x8664
sh
curl -L https://github.com/esp-rs/espup/releases/latest/download/espup-x86_64-apple-darwin -o espup
chmod a+x espup
- Windows MSVC
powershell
Invoke-WebRequest 'https://github.com/esp-rs/espup/releases/latest/download/espup-x86_64-pc-windows-msvc. exe' -OutFile .\espup.exe
See Usage section for more details.
```sh espup install
. $HOME/export-esp.sh
%USERPROFILE%export-esp.ps1 ```
Warning
The generated export file, by default
export-esp
, needs to be sourced in every terminal before building an application.
Note
The export file can be regenerated by running
espup install
again, in this case, it won't install the components again as it would detect the current installation and reuse it. The-p/--config-path
option can be used to determine where to regenerate the export file.
sh
espup uninstall
sh
espup update
```
Usage: espup
Commands: install Installs esp-rs environment uninstall Uninstalls esp-rs environment update Updates Xtensa Rust toolchain help Print this message or the help of the given subcommand(s)
Options: -h, --help Print help information -V, --version Print version information ```
Note
Xtensa Rust destination path
Installation paths can be modified by setting the environment variables
CARGO_HOME
andRUSTUP_HOME
before running theinstall
command. By default, Xtensa Rust toolchain will be installed under<rustup_home>/toolchains/esp
.
Note
ESP-IDF instalation
When building
std
applications, ESP-IDF is required, there are two ways of installing it: - Usingesp-idf-sys
, a crate that allstd
applications require (and its already included in ouresp-idf-template
). - We reccomend using this approach as its easier (you dont have to deal with ESP-IDF instalaltion and sourcing), and its more flexible. - Usingespup
.espup install
has a-e/--esp-idf-version
option that allows installing the desired ESP-IDF version. When using this argument: -ldproxy
, a tool required for allstd
projects, will be installed if not present already. - The generated export file will include the necessary environment variables for ESP-IDF - When buildingstd
applications that use the installed version of ESP-IDF,esp-idf-sys
will recognize there is an activated ESP-IDF environment and will use it instead of downloading and installing it. - This is very helpful when we want to build several projects with the same ESP-IDF version as it saves time and space. - Be aware that if you source the environment with an ESP-IDF version and you try to build andstd
application that uses a different version it will fail to build.
``` Usage: espup install [OPTIONS]
Options:
-p, --config-path
-d, --default-host
[possible values: x86_64-unknown-linux-gnu, aarch64-unknown-linux-gnu, x86_64-pc-windows-msvc, x86_64-pc-windows-gnu, x86_64-apple-darwin, aarch64-apple-darwin]
-e, --esp-idf-version
Version format:
- `commit:<hash>`: Uses the commit `<hash>` of the `esp-idf` repository.
- `tag:<tag>`: Uses the tag `<tag>` of the `esp-idf` repository.
- `branch:<branch>`: Uses the branch `<branch>` of the `esp-idf` repository.
- `v<major>.<minor>` or `<major>.<minor>`: Uses the tag `v<major>.<minor>` of the `esp-idf` repository.
- `<branch>`: Uses the branch `<branch>` of the `esp-idf` repository.
When using this option, `ldproxy` crate will also be installed.
-f, --export-file
-c, --extra-crates
-x, --llvm-version
[default: 15]
[possible values: 15]
-l, --log-level
[default: info]
[possible values: debug, info, warn, error]
-n, --nightly-version
[default: nightly]
-m, --profile-minimal Minifies the installation.
This will install a reduced version of LLVM, delete the folder where all the assets are downloaded, and, if installing ESP-IDF, delete some unnecessary folders like docs and examples.
-t, --targets
[default: all]
-v, --toolchain-version
-h, --help
Print help information (use -h
for a summary)
-V, --version Print version information ```
``` Usage: espup uninstall [OPTIONS]
Options:
-p, --config-path
``` Usage: espup update [OPTIONS]
Options:
-p, --config-path
all
targets is allowed.
ERROR: Could not find a version that satisfies the requirement windows-curses; sys_platform == "win32" (from esp-windows-curses) (from versions: none)
ERROR: No matching distribution found for windows-curses; sys_platform == "win32"
Traceback (most recent call last):
File "<home_dir>/.espressif\esp-idf-ae062fbba3ded0aa\release-v4.4\tools\idf_tools.py", line 1973, in <module>
main(sys.argv[1:])
File "<home_dir>/.espressif\esp-idf-ae062fbba3ded0aa\release-v4.4\tools\idf_tools.py", line 1969, in main
action_func(args)
File "<home_dir>/.espressif\esp-idf-ae062fbba3ded0aa\release-v4.4\tools\idf_tools.py", line 1619, in action_install_python_env
subprocess.check_call(run_args, stdout=sys.stdout, stderr=sys.stderr, env=env_copy)
File "C:\Python311\Lib\subprocess.py", line 413, in check_call
raise CalledProcessError(retcode, cmd)
subprocess.CalledProcessError: Command '['<home_dir>/.espressif\\python_env\\idf4.4_py3.11_env\\Scripts\\python.exe', '-m', 'pip', 'install', '--no-warn-script-location', '-r', <home_dir>/.espressif\\esp-idf-ae062fbba3ded0aa\\release-v4.4\\requirements.txt', '--extra-index-url', 'https://dl.espressif.com/pypi']' returned non-zero exit status 1.
Error: Could not install esp-idf
_Solution_: Use a python version between 3.6
and 3.10
as 3.11
Python wheels are not yet released for Windows.Licensed under either of:
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.