RISC-V 工具链与模拟器(emulator)的安装
闲的无聊看看 spike 源码,但是翻了很多教程都没有可以直接安装好 spike 和相关的工具链。于是自己动手丰衣足食,直接读相关仓库的 README,基本都可以安装成功,但是还是暗藏着一个小坑,记录一下。
工具链(riscv-gnu-toolchain)的安装
RISC-V 工具链包括 gcc、gdb、objdump/copy 和相关的标准库实现等,建议首先安装。
仓库地址:https://github.com/riscv-collab/riscv-gnu-toolchain
clone 时建议加上 --depth=1
参数缩小 clone 体积,后面几个仓库的 clone 也建议加此参数。
前置的依赖安装可见 README 中的 Prerequisites 一节,当前 Debian 系下为:
sudo apt install autoconf automake autotools-dev curl python3 libmpc-dev libmpfr-dev libgmp-dev gawk build-essential bison flex texinfo gperf libtool patchutils bc zlib1g-dev libexpat-dev ninja-build
clone 后按照工具链中的 Installation (Newlib)
一节基本可以安装成功,但是有坑点:
使用此方式编译的 gcc 无法编译 riscv-pk,会报 extension `zifencei' required 的错误,推测是因为默认的编译参数并不支持 zifencei 扩展(即 FENCE.I 指令)
可用的编译参数如下:
./configure --prefix=/opt/riscv --with-arch=rv64gc
make
建议首先在 /opt 下建立 riscv 文件夹,并保证 riscv 文件夹的所有人为普通用户自己。如非则需要 chown:
sudo chown 1000:1000 /opt/riscv
这里假设 uid 和 gid 皆为 1000,具体可以通过 id
命令查看。
安装完成后需要将 /opt/riscv/bin
加入 Path,具体方式可 Google 可 ChatGPT。后续安装的内容也都会放入 /opt/riscv
中。完成后 riscv64-unknown-elf-gcc
应当可用。
模拟器(spike)的安装
仓库地址:https://github.com/riscv-software-src/riscv-isa-sim
clone 下来后按照 README 中的 Build Steps 一节直接安装即可,并无坑点。当前命令:
$ sudo apt install device-tree-compiler
$ mkdir build
$ cd build
$ ../configure --prefix=/opt/riscv
$ make
$ make install
安装完成后 spike
命令应可用
模拟内核(riscv-pk) 的安装
仓库地址:https://github.com/riscv-software-src/riscv-pk
pk 即 Proxy Kernel,用来直接运行静态链接的用户态 RISCV 程序,毕竟只要验证的话,再跑一个操作系统太重了。
clone 下来后按照 README 中的 Build Steps 直接安装即可。坑点仅限于工具链一节提到的 FENCE.I 指令。当前命令:
$ mkdir build
$ cd build
$ ../configure --prefix=/opt/riscv --host=riscv64-unknown-elf
$ make
$ make install
验证
验证使用了 spike 中的例子。新建 hello.c,内容如下:
#include <stdio.h>
void main()
{
const char *s = "Hello.\n";
while (*s) putchar(*s++);
while(1);
}
编译该文件:
$ riscv64-unknown-elf-gcc -o hello hello.c
通过 spike 运行:
spike pk hello
可以看到终端输入了 Hello.,按多次 ctrl+c 可退出。