Ubuntu20.04搭建RISC-V和qemu环境

1. 前言

risc-v是一个非常有潜力的指令集框架,最近对其产生了浓厚的兴趣,由于之前对于这方面的知识储备很少,在加上网上的教程都是点到为止,所以安装过程异常曲折。好在最后一步一步积累摸索,终于利用源码安装完成。看到此文章的同学,相信你也对RISC-V感兴趣,并且在安装过程也遇到了一些问题,希望这篇文章能够帮到你。 本文假设你已经安装了ubuntu20.04或者Ubuntu18.04,我在Ubuntu18.04和Ubuntu20.04都安装成功过,Ubuntu18.04默认是python3.6,所以在安装qemu的时候需要升级python,并安装ninga. 本文使用Ubuntu20.04以源码的方式安装RISC-V和qemu,并测试其正常工作。

2. 安装RISC-V

2.1 下载risc-v的源码

risc-v地址为​​​​​​GitHub - riscv-collab/riscv-gnu-toolchain: GNU toolchain for RISC-V, including GCCGNU toolchain for RISC-V, including GCC. Contribute to riscv-collab/riscv-gnu-toolchain development by creating an account on GitHub.icon-default.png?t=N7T8https://github.com/riscv-collab/riscv-gnu-toolchain

下载后会有目录riscv-gnu-toolchain目录,该目录不大,使用GitHub可以很快下载完成。 下载命令为:git clone git@github.com:riscv-collab/riscv-gnu-toolchain.git  先不着急使用configure安装,因为安装过程会从github下载gcc,newlib等子库,速度非常慢,容易中断。继续看第二步下载子模块

2.2 子模块下载

使用浏览器打开https://github.com/riscv-collab/riscv-gnu-toolchain ,然后双击.gitmodules,可以看到每个子模块的路径和分支。根据绿色部分的名字,在国内的gitee上搜索,找到对应的库路径即可。cd riscv-gnu-toolchain 这个路径然后git clone gitee路径。 这里要注意:有的库名字和clone后的目录名字相同,有的不相同,不相同库的在切换到正确的分支后须修改为子目录名称。例如binutils库克隆后的目录为binutils-gdb,  需要先进入binutils-gdb目录,使用git checkout切换到binutils-2_40-branch分支。然后删除原有的binutils目录,在使用mv命令修改为binutils-gdb目录为binutils。  如gcc目录同gcc库名字相同,直接在gitee上找到库路径后克隆gcc库后切换到对应的分支即可。注意:子模块的目录都是空,使用clone之后都不为空,可以用来检查是否有遗漏。操作一定要小心,不然configure的时候会卡住。如果编译过程卡住2分钟,不要犹豫,直接停止编译,检查子库是否下载正确。纠正后清空build目录里面的内容重新编译。

下面是自己从gitee上找的对应模块,直接复制url的内容按删除操作一个一个clone修改即可。当然你也可以把内容复制到riscv-gnu-toolchain目录里面的.gitmodules文件里面,然后更新子模块配置,让其自动下载,这部分有兴趣可以自己研究,我这边尝试了一把卡住了没成功。

[submodule "binutils"]path = binutilsurl = https://gitee.com/keaide/binutils-gdb.gitbranch = binutils-2_40-branch
[submodule "gcc"]path = gccurl = https://gitee.com/mirrors/gcc.gitbranch = releases/gcc-13
[submodule "glibc"]path = glibcurl = https://gitee.com/rtlhq/glibc.git
[submodule "dejagnu"]path = dejagnuurl = https://gitee.com/nwpu-ercesi/dejagnu.gitbranch = master
[submodule "newlib"]path = newliburl = https://gitee.com/mirrors/newlib-cygwin.gitbranch = master
[submodule "gdb"]path = gdburl = https://gitee.com/keaide/binutils-gdb.gitbranch = gdb-13-branch
[submodule "qemu"]path = qemuurl = https://gitee.com/liwg06/qemu.git
[submodule "musl"]path = muslurl = https://gitee.com/nwpu-ercesi/musl.gitbranch = master
[submodule "spike"]path = spikeurl = https://gitee.com/houxibiao/riscv-isa-sim.gitbranch = master
[submodule "pk"]path = pkurl = https://gitee.com/houxibiao/riscv-pk.gitbranch = master
[submodule "llvm"]path = llvmurl = https://gitee.com/mirrors/LLVM.gitbranch = release/17.x

2.3 RISC-V编译

1. 正确执行2.1和2.2步骤后,可以编译安装了,按照官方文档,先执行如下命令安装库依赖:

$ sudo apt-get install 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. 在/opt目录下创建riscv目录,并修改权限为777 【很重要】

sudo mkdir /opt/riscv
sudo chmod 777 /opt/riscv

3. 在riscv-gnu-toolchain目录创建build目录,然后执行如下命令:

cd riscv-gnu-toolchain
mkdir build
cd build
../configure --prefix=/opt/riscv --enable-multilib
make linux -j 4

这里使用了兼容32和64位的模式编译,其它模式也是可以的,按照github官方文档说明即可。执行上述命令估计要40分钟左右才能编译完成。看到如下执行完成,没有卡住算是编译完成

此时/opt/riscv目录如下:

2.4. 配置RISC-V环境变量

1. 编辑~/.bashrc

vim ~/.bashrc

2. 在文件~/.bashrc末尾写入如下内容:

export RISCV="/opt/riscv"
export PATH=$PATH:$RISCV/bin

3. 使配置文件生效

source ~/.bashrc

3. 测试RISC-V

1. 创建一个hello.c文件,内容如下:

#include<stdio.h>
int main(){printf("%s","hello RISCV!");return 1;    
}

2. 使用risc-v的gcc编译 

编译无报错,说明成功。编译后是无法执行的,需要安装qemu才能执行

4. 安装QEMU

进入riscv-gnu-toolchain/qemu里面,会发现这里面也有.gitmodules, 这里面的下载路径下载速度还行,直接使用如下命令安装即可,如果卡住就按照risc-v的方法手动下载qemu的子目录即可。最新的qemu是8.1.5,我这边使用6.1稳定版

qemu的子模块目录:注意带roms的模块需要cd到roms路径克隆,不带roms切换到qemu目录克隆,带test和ui路径需要切换到test和ui目录克隆。都使用默认的master分支即可

[submodule "roms/seabios"]path = roms/seabiosurl = https://gitlab.com/qemu-project/seabios.git/
[submodule "roms/SLOF"]path = roms/SLOFurl = https://gitlab.com/qemu-project/SLOF.git
[submodule "roms/ipxe"]path = roms/ipxeurl = https://gitlab.com/qemu-project/ipxe.git
[submodule "roms/openbios"]path = roms/openbiosurl = https://gitlab.com/qemu-project/openbios.git
[submodule "roms/qemu-palcode"]path = roms/qemu-palcodeurl = https://gitlab.com/qemu-project/qemu-palcode.git
[submodule "roms/sgabios"]path = roms/sgabiosurl = https://gitlab.com/qemu-project/sgabios.git
[submodule "dtc"]path = dtcurl = https://gitlab.com/qemu-project/dtc.git
[submodule "roms/u-boot"]path = roms/u-booturl = https://gitlab.com/qemu-project/u-boot.git
[submodule "roms/skiboot"]path = roms/skibooturl = https://gitlab.com/qemu-project/skiboot.git
[submodule "roms/QemuMacDrivers"]path = roms/QemuMacDriversurl = https://gitlab.com/qemu-project/QemuMacDrivers.git
[submodule "ui/keycodemapdb"]path = ui/keycodemapdburl = https://gitlab.com/qemu-project/keycodemapdb.git
[submodule "capstone"]path = capstoneurl = https://gitlab.com/qemu-project/capstone.git
[submodule "roms/seabios-hppa"]path = roms/seabios-hppaurl = https://gitlab.com/qemu-project/seabios-hppa.git
[submodule "roms/u-boot-sam460ex"]path = roms/u-boot-sam460exurl = https://gitlab.com/qemu-project/u-boot-sam460ex.git
[submodule "tests/fp/berkeley-testfloat-3"]path = tests/fp/berkeley-testfloat-3url = https://gitlab.com/qemu-project/berkeley-testfloat-3.git
[submodule "tests/fp/berkeley-softfloat-3"]path = tests/fp/berkeley-softfloat-3url = https://gitlab.com/qemu-project/berkeley-softfloat-3.git
[submodule "roms/edk2"]path = roms/edk2url = https://gitlab.com/qemu-project/edk2.git
[submodule "slirp"]path = slirpurl = https://gitlab.com/qemu-project/libslirp.git
[submodule "roms/opensbi"]path = roms/opensbiurl = 	https://gitlab.com/qemu-project/opensbi.git
[submodule "roms/qboot"]path = roms/qbooturl = https://gitlab.com/qemu-project/qboot.git
[submodule "meson"]path = mesonurl = https://gitlab.com/qemu-project/meson.git
[submodule "roms/vbootrom"]path = roms/vbootromurl = https://gitlab.com/qemu-project/vbootrom.git

具体命令如下:

1. 创建qemu目录存放编译后的二进制文件

sudo mkdir /opt/qemu
sudo chmod 777 /opt/qemu

3. 执行如下命令,避免过程报错Dependency "pixman-1" not found, tried pkgconfig和一些依赖错误

 sudo apt-get install libpixman-1-devpip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple sphinx==5.3.0# 还有一个python依赖,没记录下来,如果出现了,执行pip3安装该库的命令即可

3. 进入riscv-gnu-toolchain/qemu创建build目录并编译,编译耗时1小时左右,出现下图即算编译成功

mkdir build
cd build
../configure --prefix=/opt/qemu
make j 4
make install

4.参考2.4配置qemu的环境变量即可,我这边最终的riscv和qemu的环境变量如下:

其中.local/bin是安装python库的时候一个告警,我手动添加的。应该不加也没事。

5. 测试QEMU(用户模式)

1.报错找不到链接库

使用qemu执行hello二进制文件报错找不到链接库

原因是:qemu-riscv64会在/lib下搜索riscv64的动态链接,而我们编译的riscv链接在/opt/riscv/sysroot里面。网上有直接copy到/lib下,但是还有其他.so文件问题,全部拷贝之后,容易把系统搞崩溃,我怀疑我的Ubuntu18.04就是这样高崩溃的。

2. 指定链接库路径执行

为了避免每次都需要手动执行动态链接库,使用 qemu-riscv64 -h发现设置QEMU的目录动态链接路径即可

3. 配置默认动态链接路径:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/161181.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【ElasticSearch系列-05】SpringBoot整合elasticSearch

ElasticSearch系列整体栏目 内容链接地址【一】ElasticSearch下载和安装https://zhenghuisheng.blog.csdn.net/article/details/129260827【二】ElasticSearch概念和基本操作https://blog.csdn.net/zhenghuishengq/article/details/134121631【三】ElasticSearch的高级查询Quer…

LeetCode热题100——链表

链表 1. 相交链表2. 反转链表3. 回文链表4. 环形链表5. 合并两个有序链表 1. 相交链表 给你两个单链表的头节点 headA 和 headB &#xff0c;请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点&#xff0c;返回 null 。 // 题解&#xff1a;使用A/B循环遍…

csapp bomb lab part4

csapp bomb lab part4 phase 5 是一个循环&#xff0c;不断累加&#xff0c;访问的地址基于0x4024b0, phase 6 之后更新 汇编 地址计算 寄存器 cl 是 x86 汇编语言中的一个 8 位寄存器&#xff0c;它是 ecx 寄存器的低位部分。 具体来说&#xff0c;x86 架构中的寄存器可…

植物花粉深度学习图片数据集大合集

最近收集了一波有关于植物花粉的图片数据集&#xff0c;可以用于相关深度学习模型的搭建&#xff0c;废话不多说&#xff0c;上数据集&#xff01;&#xff01;&#xff01; 1、23种花粉类型805张花粉图像数据集 关于此数据&#xff1a;花粉种类和类型的分类是法医抱粉学、考…

NTFS文件系统解析(三)

1、引言 对于NTFS文件系统而言&#xff0c;无论文件内容本身&#xff0c;抑或真实的文件属性&#xff0c;都被称之为属性。 而正如前文说到的&#xff0c;NTFS预定义了16种属性用于文件系统的管理。 而通常情况下&#xff0c;往往只需要关注其中的某些属性即可。 2、属性头 …

使用 Python 进行自然语言处理第 4 部分:文本表示

一、说明 本文是在 2023 年 3 月为 WomenWhoCode 数据科学跟踪活动发表的系列文章中。早期的文章位于&#xff1a;第 1 部分&#xff08;涵盖 NLP 简介&#xff09;、第 2 部分&#xff08;涵盖 NLTK 和 SpaCy 库&#xff09;、第 2 部分&#xff08;涵盖NLTK和SpaCy库&#xf…

Flask——接口路由技术

接口路由技术 一、Flask 简介1、环境安装&#xff1a;2、一个最小的应用3、两种运行方式 二、定义路由1、普通路由2、动态路由3、限定类型4、地址尾部的“/” 三、请求与响应-请求方法四、请求与响应-处理请求数据1、request的常用属性/方法2、get 请求参数3、json 请求4、表单…

手把手教程 | YOLOv8-seg训练自己的分割数据集

&#x1f680;&#x1f680;&#x1f680;手把手教程&#xff1a;教会你如何使用自己的数据集开展分割任务 &#x1f680;&#x1f680;&#x1f680;YOLOv8-seg创新专栏&#xff1a;http://t.csdnimg.cn/KLSdv 学姐带你学习YOLOv8&#xff0c;从入门到创新&#xff0c;轻轻松…

Bytedance揭秘OpenAI大模型: GPT-3到GPT-4进化路径

文章目录 探秘GPT-3到GPT-4进化之路1、SFT&#xff1a;早期GPT进化的推动者2、RLHF和SFT&#xff1a;编码能力提升的功臣3、代码加入预训练&#xff0c;对推理帮助最大4、“跷跷板”现象 论文地址项目链接Reference GPT-Fathom: Benchmarking Large Language Models to Deciphe…

Angular异步数据流编程

1 目前常见的异步编程的几种方法 首先给出一个异步请求的实例&#xff1a; import {Injectable} from angular/core;Injectable({providedIn: root }) export class RequestServiceService {constructor() {}getData() {setTimeout(() > {let res zhaoshuai-lcreturn res…

大语言模型对齐技术 最新论文及源码合集(外部对齐、内部对齐、可解释性)

大语言模型对齐(Large Language Model Alignment)是利用大规模预训练语言模型来理解它们内部的语义表示和计算过程的研究领域。主要目的是避免大语言模型可见的或可预见的风险&#xff0c;比如固有存在的幻觉问题、生成不符合人类期望的文本、容易被用来执行恶意行为等。 从必…

LangChain+LLM实战---LlamaIndex、正确使用索引

LlamaIndex简介 LlamaIndex(也称为GPT Index)是一个用户友好的界面&#xff0c;它将您的外部数据连接到大型语言模型(Large Language Models, llm)。它提供了一系列工具来简化流程&#xff0c;包括可以与各种现有数据源和格式(如api、pdf、文档和SQL)集成的数据连接器。此外&a…