项目场景:
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
原因分析:
我尝试了多种解决方案:
- 更新最新的 bsc 编译器
- 更新 github.com/bluespec/Flute 文件目录
- 查找编译器的问题(我使用的是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 测试成功!