2019-06-24 21:29:49 -04:00
***** ***** ***** ***** ***** ***** ***** ***** **
2019-06-24 21:26:53 -04:00
Setup Linux Toolchain from Scratch
2019-06-24 21:29:49 -04:00
***** ***** ***** ***** ***** ***** ***** ***** **
2019-01-27 13:01:34 -05:00
:link_to_translation:`zh_CN:[中文]`
2017-03-26 18:01:52 -04:00
2019-06-24 21:29:49 -04:00
The following instructions are alternative to downloading binary toolchain from Espressif website. To quickly setup the binary toolchain, instead of compiling it yourself, backup and proceed to section :doc: `linux-setup` .
2017-03-26 18:01:52 -04:00
2020-01-09 23:58:54 -05:00
.. note :: The reason you might need to build your own toolchain is to solve the Y2K38 problem (time_t expand to 64 bits instead of 32 bits).
2017-03-26 18:01:52 -04:00
Install Prerequisites
=====================
To compile with ESP-IDF you need to get the following packages:
2019-06-24 21:29:49 -04:00
- CentOS 7::
2021-01-11 18:57:58 -05:00
sudo yum -y update && sudo yum install git wget ncurses-devel flex bison gperf python3 python3-pip cmake ninja-build ccache dfu-util libusbx
2020-11-04 17:32:40 -05:00
CentOS 7 is still supported but CentOS version 8 is recommended for a better user experience.
2019-06-24 21:29:49 -04:00
2017-03-26 18:01:52 -04:00
- Ubuntu and Debian::
2021-01-11 18:52:06 -05:00
sudo apt-get install git wget libncurses-dev flex bison gperf python3 python3-pip python3-setuptools python3-serial python3-cryptography python3-future python3-pyparsing python3-pyelftools cmake ninja-build ccache libffi-dev libssl-dev dfu-util libusb-1.0-0
2017-03-26 18:01:52 -04:00
- Arch::
2021-01-11 18:57:58 -05:00
sudo pacman -Sy --needed gcc git make ncurses flex bison gperf python-pyserial python-cryptography python-future python-pyparsing python-pyelftools cmake ninja ccache dfu-util libusb
2017-03-26 18:01:52 -04:00
2018-08-15 03:52:07 -04:00
.. note ::
2019-06-24 21:29:49 -04:00
CMake version 3.5 or newer is required for use with ESP-IDF. Older Linux distributions may require updating, enabling of a "backports" repository, or installing of a "cmake3" package rather than "cmake".
2017-03-26 18:01:52 -04:00
Compile the Toolchain from Source
=================================
- Install dependencies:
- CentOS 7::
2020-11-04 17:32:40 -05:00
sudo yum install gawk gperf grep gettext ncurses-devel python3 python3-devel automake bison flex texinfo help2man libtool make
2017-03-26 18:01:52 -04:00
- Ubuntu pre-16.04::
2019-06-24 21:29:49 -04:00
sudo apt-get install gawk gperf grep gettext libncurses-dev python python-dev automake bison flex texinfo help2man libtool make
2017-03-26 18:01:52 -04:00
2019-03-01 04:50:16 -05:00
- Ubuntu 16.04 or newer::
2017-03-26 18:01:52 -04:00
2019-06-24 21:29:49 -04:00
sudo apt-get install gawk gperf grep gettext python python-dev automake bison flex texinfo help2man libtool libtool-bin make
2017-03-26 18:01:52 -04:00
2018-01-05 04:48:35 -05:00
- Debian 9::
2017-03-26 18:01:52 -04:00
2019-06-24 21:29:49 -04:00
sudo apt-get install gawk gperf grep gettext libncurses-dev python python-dev automake bison flex texinfo help2man libtool libtool-bin make
2017-03-26 18:01:52 -04:00
- Arch::
2020-11-04 17:32:40 -05:00
sudo pacman -Sy --needed python-pip
2017-03-26 18:01:52 -04:00
2018-10-22 01:45:09 -04:00
Create the working directory and go into it::
mkdir -p ~/esp
cd ~/esp
2018-08-29 09:30:03 -04:00
Download `` crosstool-NG `` and build it:
2017-03-26 18:01:52 -04:00
2019-11-12 22:46:16 -05:00
.. include-build-file :: inc/scratch-build-code.inc
2017-03-26 18:01:52 -04:00
2020-01-09 23:58:54 -05:00
.. note :: To create a toolchain with support for 64-bit time_t, you need to remove the `` --enable-newlib-long-time_t `` option from the `` crosstool-NG/samples/xtensa-esp32-elf/crosstool.config `` file in 33 and 43 lines.
2017-03-26 18:01:52 -04:00
Build the toolchain::
2021-01-26 21:12:58 -05:00
./ct-ng {IDF_TARGET_TOOLCHAIN_PREFIX}
2017-03-26 18:01:52 -04:00
./ct-ng build
2021-01-26 21:12:58 -05:00
chmod -R u+w builds/{IDF_TARGET_TOOLCHAIN_PREFIX}
2017-03-26 18:01:52 -04:00
2021-01-26 21:12:58 -05:00
Toolchain will be built in `` ~/esp/crosstool-NG/builds/{IDF_TARGET_TOOLCHAIN_PREFIX} `` .
2019-11-26 01:22:50 -05:00
Add Toolchain to PATH
=====================
The custom toolchain needs to be copied to a binary directory and added to the `` PATH `` .
2021-01-26 21:12:58 -05:00
Choose a directory, for example `` ~/esp/{IDF_TARGET_TOOLCHAIN_PREFIX}/ `` , and copy the build output to this directory.
2019-11-26 01:22:50 -05:00
2021-01-26 21:12:58 -05:00
To use it, you will need to update your `` PATH `` environment variable in `` ~/.profile `` file. To make `` {IDF_TARGET_TOOLCHAIN_PREFIX} `` available for all terminal sessions, add the following line to your `` ~/.profile `` file::
2019-11-26 01:22:50 -05:00
2021-01-26 21:12:58 -05:00
export PATH="$HOME/esp/{IDF_TARGET_TOOLCHAIN_PREFIX}/bin:$PATH"
2019-11-26 01:22:50 -05:00
.. note ::
If you have `` /bin/bash `` set as login shell, and both `` .bash_profile `` and `` .profile `` exist, then update `` .bash_profile `` instead. In CentOS, `` alias `` should set in `` .bashrc `` .
Log off and log in back to make the `` .profile `` changes effective. Run the following command to verify if `` PATH `` is correctly set::
printenv PATH
You are looking for similar result containing toolchain's path at the beginning of displayed string::
$ printenv PATH
2021-01-26 21:12:58 -05:00
/home/user-name/esp/{IDF_TARGET_TOOLCHAIN_PREFIX}/bin:/home/user-name/bin:/home/user-name/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin
2019-11-26 01:22:50 -05:00
Instead of `` /home/user-name `` there should be a home path specific to your installation.
2017-03-26 18:01:52 -04:00
2020-11-04 17:32:40 -05:00
Python 2 deprecation
====================
Python 2 reached its `end of life <https://www.python.org/doc/sunset-python-2/> `_ and support for it in ESP-IDF will be removed soon. Please install Python 3.6 or higher. Instructions for popular Linux distributions are listed above.
2017-03-26 18:01:52 -04:00
Next Steps
==========
2019-06-24 21:26:53 -04:00
To carry on with development environment setup, proceed to :ref: `get-started-get-esp-idf` .