Bluespec System Verilog , Flute 开源RISC-V处理器 构建过程问题

文章讲述了在使用Bluespec开源FluteRISC-V处理器时,构建仿真平台遇到的‘额外重寻址溢出’错误。通过尝试更新BSC编译器、更换低版本GCC/g++并修复符号链接,最终解决了这个问题并成功进行了单个ISA测试。
摘要由CSDN通过智能技术生成

项目场景:

Bluespec, Inc. 在 GitHub 上提供的免费的开源 RISC-V 处理器–“Flute”(简单的 5 级、无序、部分控制流推测和分支预测)

Build 仿真过程出现 BUG


问题描述

构建好仿真平台之后,进行 make test 的过程中出现以下错误:

“从输出所省略的额外重寻址溢出”
“error: ld returned 1 exit status”

/home/xuzhengli01/xmu/Study_Data/Work/Flute-master/Tests/elf_to_hex/elf_to_hex.c:158:
(.text+0x515): 从输出所省略的额外重寻址溢出
collect2: error: ld returned 1 exit status

原因分析:

我尝试了多种解决方案:

  1. 更新最新的 bsc 编译器
  2. 更新 github.com/bluespec/Flute 文件目录
  3. 查找编译器的问题(我使用的是Ubuntu 22.04.4 LTS ,gcc -11 和 g++ -11)

通过以上三个步骤并且对编译器重新安装也未能解决问题。


解决方案:

更换低版本的 gcc 以及 g++ 编译器 (gcc -9 、 g++ -9)

依次执行以下命令

sudo apt purge gcc g++ 
sudo add-apt-repository ppa:ubuntu-toolchain-r/test
sudo apt update
sudo apt install gcc-9 g++-9

之后手动更改 /usr/bin/gcc 和 /usr/bin/g++ 这两个文件的符号链接

sudo rm /usr/bin/gcc
sudo rm /usr/bin/g++
sudo ln -s /usr/bin/gcc-9 /usr/bin/gcc
sudo ln -s /usr/bin/g++-9 /usr/bin/g++

最后确认把 /usr/bin/gcc 和 /usr/bin/g++ 两个文件链接到 GCC 9.5.0 版本。

gcc --version
g++ --version

最后再回到 Flute 仿真平台目录进行 make test ,bug 解决,单个 ISA 测试成功!

  • 17
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值