| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485 |
- ***********************************************
- Setup Toolchain for Mac OS from Scratch
- ***********************************************
- :link_to_translation:`zh_CN:[中文]`
- Package Manager
- ===============
- To set up the toolchain from scratch, rather than :doc:`downloading a pre-compiled toolchain<macos-setup>`, you will need to install either the MacPorts_ or Homebrew_ package manager.
- MacPorts needs a full XCode installation, while Homebrew only needs XCode command line tools.
- .. _Homebrew: https://brew.sh/
- .. _MacPorts: https://www.macports.org/install.php
- 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.
- Install Prerequisites
- =====================
- - install pip::
- sudo easy_install pip
- - install pyserial::
- pip install --user pyserial
- - install CMake & Ninja build:
- - If you have Homebrew, you can run::
- brew install cmake ninja dfu-util
- - If you have MacPorts, you can run::
- sudo port install cmake ninja dfu-util
- Compile the Toolchain from Source
- =================================
- Install dependencies:
- - with MacPorts::
- sudo port install gsed gawk binutils gperf grep gettext wget libtool autoconf automake make
- - with Homebrew::
- brew install gnu-sed gawk binutils gperftools gettext wget help2man libtool autoconf automake make
- Create a case-sensitive filesystem image::
- hdiutil create ~/esp/crosstool.dmg -volname "ctng" -size 10g -fs "Case-sensitive HFS+"
- Mount it::
- hdiutil mount ~/esp/crosstool.dmg
- Create a symlink to your work directory::
- mkdir -p ~/esp
- ln -s /Volumes/ctng ~/esp/ctng-volume
- Go into the newly created directory::
- cd ~/esp/ctng-volume
- Download ``crosstool-NG`` and build it:
- .. include-build-file:: inc/scratch-build-code.inc
- Build the toolchain::
- ./ct-ng {IDF_TARGET_TOOLCHAIN_PREFIX}
- ./ct-ng build
- chmod -R u+w builds/{IDF_TARGET_TOOLCHAIN_PREFIX}
- Toolchain will be built in ``~/esp/ctng-volume/crosstool-NG/builds/{IDF_TARGET_TOOLCHAIN_PREFIX}``. To use it, you need to add ``~/esp/ctng-volume/crosstool-NG/builds/{IDF_TARGET_TOOLCHAIN_PREFIX}/bin`` to ``PATH`` environment variable.
- Next Steps
- ==========
- To carry on with development environment setup, proceed to :ref:`get-started-get-esp-idf`.
|