RISC-V交叉工具链riscv-gnu-toolchain编译

文章目录

1、下载

shell 复制代码
$ sudo apt-get install git wget build-essential 
$ git clone https://github.com/riscv-collab/riscv-gnu-toolchain
$ git checkout 2023.06.02

注意上面 clone 的仓库,我们称其为构建脚本仓库,其并不包含 gcc 等工具源码,这些源码以 git 的 submodule 的形式作为子仓库的内容发布,所以需要继续更新子仓库。

shell 复制代码
$ git submodule update --init --recursive

Submodule 'binutils' (https://sourceware.org/git/binutils-gdb.git) registered for path 'binutils'
Submodule 'dejagnu' (https://git.savannah.gnu.org/git/dejagnu.git) registered for path 'dejagnu'
Submodule 'gcc' (https://gcc.gnu.org/git/gcc.git) registered for path 'gcc'
Submodule 'gdb' (https://sourceware.org/git/binutils-gdb.git) registered for path 'gdb'
Submodule 'glibc' (https://sourceware.org/git/glibc.git) registered for path制作交叉工具链 riscv-gnu-toolchain

注意:

使用上诉命令通过 submodule 方式下载困难的话,可以手工通过下载并切换到指定的分支。如 binutils 可通过以下方式下载并切换到指定的分支,地址和分支可以在根目录下的 .gitignore 文件中获取。

shell 复制代码
$ git clone https://sourceware.org/git/binutils-gdb.git binutils
$ git checkout binutils-2_40-branch

2、编译

1. 依赖安装

shell 复制代码
$ sudo apt-get install -y autoconf automake autotools-dev curl python3 python3-pip libmpc-dev libmpfr-dev libgmp-dev gawk build-essential bison flex texinfo gperf libtool patchutils bc zlib1g-dev libexpat-dev ninja-build git cmake libglib2.0-dev

2. 编译

riscv-gnu-toolchain 支持通过不同的编译命令和参数,生成不同版本的 toolchain。

分别支持:

  • 32bit 和 64bit
  • Newlib、glibc 和 musl 版本
  1. 编译 Newlib 版本:使用 make 命令
shell 复制代码
$ ./configure --prefix=${PWD}/riscv-newlib
$ make -j8

编译完成后,在 ${PWD}/riscv-newlib/bin 目录下生成 riscv64-unknown-elf-gcc

  1. 编译 glibc 版本:使用 make linx 命令
shell 复制代码
$ ./configure --prefix=${PWD}/riscv64-linux
$ make linux -j8

默认编译的版本为 RV64GC (64-bit), 需要编译 RV32GC (32bit) 版本可以使用以下命令编译

shell 复制代码
$ ./configure --prefix=${PWD}/riscv32-linux --with-arch=rv32gc --with-abi=ilp32d
$ make linux -j8
  • 支持的架构是rv32i或rv64i加上标准扩展 a/m/f/d/g
  • 支持的ABI是ilp32(32位软浮点),ilp32d(32位硬浮点),ilp32f(32位,在寄存器中使用单精度,在内存中使用双精度,仅限特定用途),lp64,lp64f,lp64d(相同,但使用64位长和指针)。
  1. 编译 musl libc 版本:使用 make musl 命令
shell 复制代码
$ ./configure --prefix=${PWD}/riscv64-musl
$ make musl -j8
  1. 同时编译支持 32bit 和 64bit 版本
shell 复制代码
$ ./configure --prefix=${PWD}/riscv --enable-multilib

然后使用 makemake linuxmake musl 编译对应的版本。

注:

musl 只支持 64bit 系统。

更多的配置信息可以通过 ./configure --help 查看。

3、运行

测试 toolchain 是否安装成功

shell 复制代码
$ riscv64-unknown-linux-gnu-gcc -v
相关推荐
国科安芯17 小时前
IAR全面支持国科环宇AS32X系列RISC-V车规MCU
人工智能·单片机·mcu·risc-v
红叶落水17 小时前
RISC-V开发 linux下GCC编译自定义指令流程笔记
risc-v
电子科技圈2 天前
智权半导体/SmartDV力助高速发展的中国RISC-V CPU IP厂商走上高质量发展之道
嵌入式硬件·mcu·risc-v
代吗喽6 天前
深入解析 RISC-V 递归函数的栈使用:以阶乘函数为例
risc-v·计算机组成
KGback9 天前
【论文解析】基于开源 Matrix 指令集扩展(矢量点积)的高性能 RISC-V 处理器“香山”(nanhu 版本)的 LLM 加速的研究
fpga开发·risc-v
思尔芯S2C9 天前
What is RISC-V?
fpga开发·soc·risc-v·eda·fpga原型验证·prototyping·verification
百里杨15 天前
RISC-V交叉编译器下载
risc-v·下载·交叉编译器
ERIC-ZI15 天前
[ IDE ] SEGGER Embedded Studio for RISC-V
risc-v
码尔泰21 天前
CISC 和 RISC 架构的对比
架构·risc-v·cisc·risc
RT-Thread物联网操作系统1 个月前
睿赛德科技携手先楫共创RISC-V生态|RT-Thread EtherCAT主从站方案大放异彩
大数据·人工智能·科技·物联网·risc-v