查看: 809|回复: 0
收起左侧

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

[复制链接]

  离线 

  • TA的每日心情
    慵懒
    2021-7-23 17:16
  • 签到天数: 17 天

    [LV.4]

    发表于 2021-9-16 21:22:39 | 显示全部楼层 |阅读模式

    有人预言,RISC-V或将是继Intel和Arm之后的第三大主流处理器体系。欢迎访问全球首家只专注于RISC-V单片机行业应用的中文网站

    您需要 登录 才可以下载或查看,没有帐号?立即注册

    x
    本帖最后由 草帽王子 于 2021-9-16 21:22 编辑

    除了从乐鑫官网直接下载已编译好的二进制工具链外,您还可以按照本文介绍,从头开始设置自己的工具链。如需快速使用已编译好的二进制工具链,可回到 Linux 平台工具链的标准设置 章节。
    注解
    设置自己的工具链可以解决 Y2K38 问题(time_t 从 32 位扩展到 64 位)。


    安装准备

    编译 ESP-IDF 需要以下软件包:
    • CentOS 7:
    1. sudo yum -y update && sudo yum install git wget ncurses-devel flex bison gperf python3 python3-pip cmake ninja-build ccache dfu-util libusbx
    复制代码
    目前仍然支持 CentOS 7,但为了更好的用户体验,建议使用 CentOS 8。
    • Ubuntu 和 Debian:
    1. 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 dfu-util libusb-1.0-0
    复制代码
    • Arch:
    1. 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 libusb
    复制代码
    注解
    使用 ESP-IDF 需要 CMake 3.5 或以上版本。较早的 Linux 发行版可能需要升级自身的软件源仓库,或开启 backports 套件库,或安装 “cmake3” 软件包(不是安装 “cmake”)。


    从源代码编译工具链

    安装依赖项:
    • CentOS 7:
    1. sudo yum install gawk gperf grep gettext ncurses-devel python3 python3-devel automake bison flex texinfo help2man libtool make
    复制代码
    • Ubuntu pre-16.04:
    1. sudo apt-get install gawk gperf grep gettext libncurses-dev python python-dev automake bison flex texinfo help2man libtool make
    复制代码
    • Ubuntu 16.04 或以上
    1. sudo apt-get install gawk gperf grep gettext python python-dev automake bison flex texinfo help2man libtool libtool-bin make
    复制代码
    • Debian 9:
    1. sudo apt-get install gawk gperf grep gettext libncurses-dev python python-dev automake bison flex texinfo help2man libtool libtool-bin make
    复制代码
    • Arch:
    1. sudo pacman -Sy --needed python-pip
    复制代码
    创建工作目录,并进入该目录:
    1. mkdir -p ~/esp
    2. cd ~/esp
    复制代码
    下载并编译 crosstool-NG:
    1. git clone https://github.com/espressif/crosstool-NG.git
    2. cd crosstool-NG
    3. git checkout esp-2021r1
    4. git submodule update --init
    5. ./bootstrap && ./configure --enable-local && make
    复制代码
    注解
    在设置支持 64 位 time_t 的工具链时,您需要将 crosstool-NG/samples/xtensa-esp32-elf/crosstool.config 文件中第 33 和 43 行的可选参数 --enable-newlib-long-time_t 删除。


    编译工具链:
    1. ./ct-ng riscv32-esp-elf
    2. ./ct-ng build
    3. chmod -R u+w builds/riscv32-esp-elf
    复制代码
    编译得到的工具链会被保存至 ~/esp/crosstool-NG/builds/riscv32-esp-elf。

    添加工具链到 PATH 环境变量

    需要将自定义工具链复制到一个二进制目录中,并将其添加到 PATH 中。例如,您可以将编译好的工具链复制到 ~/esp/riscv32-esp-elf/ 目录中。

    为了正常使用工具链,您需要更新 ~/.profile 文件中 PATH 环境变量。此外,您还可以在 ~/.profile 文件中增加以下代码。这样,所有终端窗口均可以使用 riscv32-esp-elf:
    1. export PATH="$HOME/esp/riscv32-esp-elf/bin:$PATH"
    复制代码
    注解
    如果您已将 /bin/bash 设置为登录 shell,且同时存在 .bash_profile 和 .profile 两个文件,则请更新 .bash_profile。在 CentOS 环境下, alias 需要添加到 .bashrc 文件中。


    退出并重新登录以使 .profile 的更改生效。运行以下命令来检查 PATH 设置是否正确:
    1. printenv PATH
    复制代码
    此时您需要检查输出结果的开头中是否包含类似如下的工具链路径:
    1. $ printenv PATH
    2. /home/user-name/esp/riscv32-esp-elf/bin:/home/user-name/bin:/home/user-name/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin
    复制代码
    注意这里的 /home/user-name 应该替换成您安装的主路径。

    后续步骤

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

    ESP32-C3 单片机芯片-从零开始设置 Linux 环境下的工具链risc-v单片机中文社区(1)







    上一篇:工具链的自定义设置
    下一篇:从零开始设置 macOS 环境下的工具链
    RISCV作者优文
    全球首家只专注于RISC-V单片机行业应用的中文网站
    回复

    使用道具 举报

    高级模式
    B Color Image Link Quote Code Smilies

    本版积分规则

    关闭

    RISC-V单片机中文网上一条 /2 下一条



    版权及免责声明|RISC-V单片机中文网 |网站地图

    GMT+8, 2024-9-15 18:41 , Processed in 0.489229 second(s), 48 queries .

    快速回复 返回顶部 返回列表