用最小的 RISC-V 核心挑战 FPGA 极限

在 FPGA 设计领域,资源利用率和性能优化始终是工程师关注的焦点。CoreScore 是一个开源项目,旨在通过部署尽可能多的 SERV 核心(世界上最小的 RISC-V 处理器)在 FPGA 上,评估 FPGA 的资源承载能力和综合布线工具的效率。

什么是 CoreScore?

CoreScore 是由 Olof Kindgren 发起的开源基准测试项目,利用 SERV 核心在不同 FPGA 上进行部署,测试其最大承载能力。该项目不仅评估 FPGA 的资源利用率,还考察综合(Synthesis)和布局布线(Place & Route)工具的性能。

SERV 核心简介

SERV(SErial RISC-V)是目前已知最小的 RISC-V 处理器核心,由 Olof Kindgren 开发。其设计目标是极致精简,适用于资源受限的应用场景。SERV 的体积小巧,使其成为在 FPGA 上进行大规模部署的理想选择。

CoreScore 的工作原理与流程

CoreScore 的主要流程包括:

环境准备:安装 FuseSoC 工具,设置工作目录,并添加必要的库。

目标选择:选择支持的 FPGA 开发板作为目标,例如 CYC1000。

构建与部署:使用 FuseSoC 构建项目,并将生成的比特流文件部署到 FPGA 上。

结果评估:运行 corecount 工具,通过串口通信获取实际部署的 SERV 核心数量。

该流程不仅测试了 FPGA 的资源承载能力,还评估了综合和布局布线工具的效率。

一、安装FuseSoC

go 复制代码
pip install fusesoc

设置工作区目录并获取 FuseSoC 基础库

go 复制代码
mkdir workspace
cd workspace
fusesoc library add fusesoc-cores https://github.com/fusesoc/fusesoc-cores

将 CoreScore 添加为工作区中的库

go 复制代码
fusesoc library add corescore https://github.com/olofk/corescore

检查可用的 corescore 目标

go 复制代码
fusesoc core show corescore

构建一个受支持的目标(cyc1000 是当前支持的核心之一)

go 复制代码
fusesoc run --target=cyc1000 corescore

如果电路板已连接,则会自动编程。否则,请连接并运行fusesoc run --run --target=cyc1000 corescore编程,无需重建

运行 corecount 实用程序(可能需要调整正确的 UART 端口)

go 复制代码
python3 fusesoc_libraries/corescore/sw/corecount.py /dev/ttyUSB0

CoreScore 世界排名

CoreScore 项目维护了一个世界排名榜,记录了在不同 FPGA 上成功部署的 SERV 核心数量。这一排名激励了全球的开发者不断挑战 FPGA 的极限,推动了硬件设计的创新。

https://corescore.store/

如何参与 CoreScore 项目

CoreScore 项目托管在 GitHub 上,任何人都可以访问其源代码、文档和示例设计。项目采用 Apache-2.0 许可证,允许自由使用、修改和分发。开发者可以通过提交问题、贡献代码或改进文档的方式参与其中。

GitHub:

https://github.com/olofk/corescore

总结

随着 FPGA 技术的不断发展,CoreScore 项目也在持续进化。未来,CoreScore 将继续致力于推动开源 FPGA 设计工具的发展,降低硬件设计的门槛,促进创新和研究。

相关推荐
KOAN凯擎小妹13 小时前
晶振信号质量:上升下降时间与占空比
单片机·嵌入式硬件·fpga开发·信息与通信
cmc102814 小时前
148.PCIE参考时钟无法绑定
fpga开发
我爱C编程17 小时前
【硬件片内测试】基于FPGA的完整BPSK链路测试,含频偏锁定,帧同步,定时点,Viterbi译码,信道,误码统计
fpga开发·定时·bpsk·帧同步·卷积编码·维特比译码·频偏估计
FPGA_小田老师17 小时前
FPGA基础知识(十一):时序约束参数确定--从迷茫到精通
fpga开发·时序约束·建立时间·保持时间·约束参数计算
FPGA_小田老师17 小时前
FPGA基础知识(十二):详解跨时钟域约束
fpga开发·时序约束·跨时钟域·约束完整性
第二层皮-合肥1 天前
基于FPGA的雷达信号处理设计工具包分享
fpga开发·信号处理
美好的事情总会发生1 天前
FPGA的LVDS接口电压
嵌入式硬件·fpga开发·硬件工程·智能硬件
卡奥斯开源社区官方2 天前
量子计算“平价革命”深度解析:AMD破局FPGA方案+中国千比特云服务,技术拐点已至?
fpga开发·量子计算
贝塔实验室2 天前
译码器的结构
驱动开发·算法·网络安全·fpga开发·硬件工程·信息与通信·信号处理
bnsarocket2 天前
Verilog和FPGA的自学笔记9——呼吸灯
笔记·fpga开发·verilog·自学·硬件编程