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