2019-10-10 16:52:07 +08:00
|
|
|
|
***********************************************
|
2020-11-30 20:11:36 +08:00
|
|
|
|
从零开始设置 macOS 环境下的工具链
|
2019-10-10 16:52:07 +08:00
|
|
|
|
***********************************************
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
:link_to_translation:`en:[English]`
|
2018-10-22 18:26:44 +08:00
|
|
|
|
|
2019-06-25 11:26:53 +10:00
|
|
|
|
软件包管理器
|
2019-10-10 16:52:07 +08:00
|
|
|
|
===============
|
2019-06-25 11:26:53 +10:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
从零开始设置工具链,您需要安装 MacPorts_ 或 homebrew_ 软件包管理器。或者,您也可以直接 :doc:`下载预编译的工具链 <macos-setup>`。
|
2019-06-25 11:26:53 +10:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
MacPorts 需要完整的 XCode 软件,而 homebrew 只需要安装 XCode 命令行工具即可。
|
2019-06-25 11:26:53 +10:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
.. _homebrew: https://brew.sh/
|
|
|
|
|
.. _MacPorts: https://www.macports.org/install.php
|
2019-06-25 11:26:53 +10:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
请参考 :ref:`工具链自定义设置 <get-started-customized-setup>` 章节,查看可能需要从头开始设置工具链的情况。
|
2019-06-25 11:26:53 +10:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
安装准备
|
|
|
|
|
=====================
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
|
|
|
|
- 安装 pip::
|
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
sudo easy_install pip
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2019-06-25 11:26:53 +10:00
|
|
|
|
- 安装 pyserial::
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
pip install --user pyserial
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2019-06-25 11:26:53 +10:00
|
|
|
|
- 安装 CMake 和 Ninja 编译工具:
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
- 若有 HomeBrew,您可以运行::
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2020-04-06 16:41:44 +02:00
|
|
|
|
brew install cmake ninja dfu-util
|
2019-06-25 11:26:53 +10:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
- 若有 MacPorts,您可以运行::
|
2019-06-25 11:26:53 +10:00
|
|
|
|
|
2020-04-06 16:41:44 +02:00
|
|
|
|
sudo port install cmake ninja dfu-util
|
2019-06-25 11:26:53 +10:00
|
|
|
|
|
|
|
|
|
从源代码编译工具链
|
2019-10-10 16:52:07 +08:00
|
|
|
|
=================================
|
2019-06-25 11:26:53 +10:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
安装依赖项:
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
- 对于 MacPorts::
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
sudo port install gsed gawk binutils gperf grep gettext wget libtool autoconf automake make
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
- 对于 homebrew::
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
brew install gnu-sed gawk binutils gperftools gettext wget help2man libtool autoconf automake make
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2019-06-25 11:26:53 +10:00
|
|
|
|
创建一个文件系统镜像(区分大小写)::
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
hdiutil create ~/esp/crosstool.dmg -volname "ctng" -size 10g -fs "Case-sensitive HFS+"
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
|
|
|
|
挂载::
|
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
hdiutil mount ~/esp/crosstool.dmg
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
创建指向您工作目录的符号链接::
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
mkdir -p ~/esp
|
|
|
|
|
ln -s /Volumes/ctng ~/esp/ctng-volume
|
2018-10-22 18:26:44 +08:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
前往新创建的目录 ::
|
2018-10-22 18:26:44 +08:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
cd ~/esp/ctng-volume
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2019-12-10 14:55:35 +08:00
|
|
|
|
下载并编译 ``crosstool-NG``
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2019-11-13 11:46:16 +08:00
|
|
|
|
.. include-build-file:: inc/scratch-build-code.inc
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2019-10-10 16:52:07 +08:00
|
|
|
|
编译工具链::
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2019-12-10 14:55:35 +08:00
|
|
|
|
./ct-ng xtensa-{IDF_TARGET_TOOLCHAIN_NAME}-elf
|
2019-10-10 16:52:07 +08:00
|
|
|
|
./ct-ng build
|
2019-12-10 14:55:35 +08:00
|
|
|
|
chmod -R u+w builds/xtensa-{IDF_TARGET_TOOLCHAIN_NAME}-elf
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
2019-12-10 14:55:35 +08:00
|
|
|
|
编译得到的工具链会被保存到 ``~/esp/ctng-volume/crosstool-NG/builds/xtensa-{IDF_TARGET_TOOLCHAIN_NAME}-elf``。使用工具链前,请将 ``~/esp/ctng-volume/crosstool-NG/builds/xtensa-{IDF_TARGET_TOOLCHAIN_NAME}-elf/bin`` 添加至 ``PATH`` 环境变量。
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|
|
|
|
|
|
2020-11-30 20:11:36 +08:00
|
|
|
|
停用 Python 2
|
|
|
|
|
====================
|
|
|
|
|
|
|
|
|
|
Python 2 已经 `结束生命周期 <https://www.python.org/doc/sunset-python-2/>`_,ESP-IDF 很快将不再支持 Python 2。请安装 Python 3.6 或以上版本。可参考上面列出的 macOS 安装说明。
|
|
|
|
|
|
|
|
|
|
|
2019-06-25 11:26:53 +10:00
|
|
|
|
后续步骤
|
2019-10-10 16:52:07 +08:00
|
|
|
|
==========
|
|
|
|
|
|
|
|
|
|
继续设置开发环境,请前往 :ref:`get-started-get-esp-idf` 章节。
|
2018-08-16 10:31:04 +08:00
|
|
|
|
|