linux-setup-scratch.rst 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. **********************************
  2. Setup Linux Toolchain from Scratch
  3. **********************************
  4. :link_to_translation:`zh_CN:[中文]`
  5. .. note::
  6. Standard process for installing the toolchain is described :doc:`here <linux-setup>`. See :ref:`Customized Setup of Toolchain <get-started-customized-setup>` section for some of the reasons why installing the toolchain from scratch may be necessary.
  7. Install Prerequisites
  8. =====================
  9. To compile with ESP-IDF you need to get the following packages:
  10. - Ubuntu and Debian::
  11. 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
  12. - Arch::
  13. 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
  14. .. note::
  15. Some older (pre-2014) Linux distributions may use ``pyserial`` version 2.x which is not supported by ESP-IDF.
  16. In this case please install a supported version via ``pip`` as it is described in section
  17. :ref:`get-started-get-packages`.
  18. Compile the Toolchain from Source
  19. =================================
  20. - Install dependencies:
  21. - CentOS 7::
  22. sudo yum install gawk gperf grep gettext ncurses-devel python3 python3-devel automake bison flex texinfo help2man libtool make
  23. - Ubuntu pre-16.04::
  24. sudo apt-get install gawk gperf grep gettext libncurses-dev python python-dev automake bison flex texinfo help2man libtool
  25. - Ubuntu 16.04 or newer::
  26. sudo apt-get install gawk gperf grep gettext python python-dev automake bison flex texinfo help2man libtool libtool-bin
  27. - Debian 9::
  28. sudo apt-get install gawk gperf grep gettext libncurses-dev python python-dev automake bison flex texinfo help2man libtool libtool-bin
  29. - Arch::
  30. sudo pacman -Sy --needed python-pip
  31. Create the working directory and go into it::
  32. mkdir -p ~/esp
  33. cd ~/esp
  34. Download ``crosstool-NG`` and build it:
  35. .. include:: /_build/inc/scratch-build-code.inc
  36. Build the toolchain::
  37. ./ct-ng xtensa-esp32-elf
  38. ./ct-ng build
  39. chmod -R u+w builds/xtensa-esp32-elf
  40. Toolchain will be built in ``~/esp/crosstool-NG/builds/xtensa-esp32-elf``. Follow :ref:`instructions for standard setup <setup-linux-toolchain-add-it-to-path>` to add the toolchain to your ``PATH``.
  41. Python 2 deprecation
  42. ====================
  43. 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.
  44. Next Steps
  45. ==========
  46. To carry on with development environment setup, proceed to section :ref:`get-started-get-esp-idf`.