从零开始设置 MacOS 环境下的工具链

[English]

软件包管理器

从零开始设置工具链,您需要安装 MacPortshomebrew 软件包管理器。或者,您也可以直接 下载预编译的工具链

MacPorts 需要完整的 XCode 软件,而 homebrew 只需要安装 XCode 命令行工具即可。

请参考 工具链自定义设置 章节,查看可能需要从头开始设置工具链的情况。

安装准备

  • 安装 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

git clone https://github.com/espressif/crosstool-NG.git
cd crosstool-NG
git checkout esp-2019r2
git submodule update --init
./bootstrap && ./configure --enable-local && make

编译工具链:

./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 环境变量。

后续步骤

继续设置开发环境,请前往 第二步:获取 ESP-IDF 章节。