系列文章目录
分享一些fpga内使用riscv软核的经验,共大家参考。后续内容比较多,会做成一个系列。
【risc-v】易灵思efinix FPGA sapphire_soc IP配置参数分享-CSDN博客
【risc-v】易灵思efinix FPGA riscv 时钟配置的一些总结-CSDN博客
前言
在efinix fpga中使用riscv是一件相对容易的事,efinix官方提供了一套集成riscv核心的应用IP,在IP catalog中可以很方便的生成、修改。裁剪IP的功能。
上一节我们在efinity IP catalog中选择生成了 riscv IP,在【Deliverables】页可见默认勾选了【embedded_sw】。
源码文件夹的生成
IP核生成的同时,会在FPGA工程根目录生成【embedded_sw】文件夹
我选择是riscv ip是sapphire,因此自动产生【sapphire_soc】文件夹,展开这个文件夹有如下文件夹
文件说明
•config–适用于Windows系统的Eclipse项目设置文件和OpenOCD调试配置设置文件。
•config_linux–适用于linux系统的Eclipse项目设置文件和OpenOCD调试配置设置文件。
【BSP】
板级支持包(BSP)定义了地址映射,并与Sapphire SoC硬件地址映射对齐。BSP文件位于nbsp/efinix/EfxSapphireSoC子目录中。
文件或目录 |
|
【config】和【config_linux】
Efinix在【config】和【config_linux】文件夹提供了一个C/C++项目设置文件,该文件定义了C代码的包含路径和符号。将这些设置导入到项目中可以让您轻松地浏览和跳过代码。
2.展开C/C++。
5.单击“设置”文件框旁边的“浏览”。
8.单击“完成”。
Eclipse在项目中创建一个名为Includes的新文件夹,其中包含项目使用的所有文件。导入设置后,请清理项目(Project > Clean),然后生成(Project> Build Project
【software】
Efinix提供了各种示例软件代码,用于执行诸如通过UART通信、控制GPIO中断、执行Dhrystone基准测试等功能。每个示例都包括一个makefile和包含源代码的src目录。
延伸
—关于易灵思
易灵思是一家国产FPGA公司,采用逻辑和路由可以互换的XLR结构,发明了突破性的Quantum架构,PPA优势是传统世界领先FPGA公司的4倍。公司从架构与IC设计、工艺制程、封装与测试、成本/品质/交付管控,到EDA工具设计、 IP与应用方案设计、营销与技术支持,均坚持质与量并行,力求问鼎行业桂冠。
RISC-V是一个开源的标准指令集架构(ISA,包含基本指令集和可选的扩展集),由非盈利的RISC-V基金会管理。由于RISC-V是免费的和开源的,它已经在世界范围内流行起来,目前有超过65个开源或商用的RISC-V内核。易灵思基于Charles Papon提出的VexRiscv核心创建了RISC-V SoC。
VexRiscv在2018年的RISC-V SoftCPU竞赛中获得第一名,是一个32位CPU,使用ISA RISCV32I具有M和C两种扩展模式,有五级流水(读取、解码、执行、内存和回写),以及一个可配置的特征集。SoC具有RISC-V处理器、内存、一系列I/O和用于嵌入用户功能的接口。您可以轻松地在同一个钛金系列或Trion®系列FPGA中创建包含嵌入式计算和用户定义加速器的完整系统。
- VexRiscv处理器,具有5级流水 (读取,解码,执行,内存,回写),中断和机器模式(Machine Mode)的异常处理
- 20 – 400 MHz 系统时钟频率
- 4 – 512 KB 带SPI flash引导加载程序的片上RAM
- DDR或HyperRAM的内存控制器
- 多达2个AXI主通道用于用户逻辑
- 1 AXI从通道到用户逻辑
- 包含浮点运算单元
- 包含一个可选的Linux内存管理单元(MMU)
- 包含一个具有1024个ID的自定义指令接口,以执行不同的功能
- 支持可选的RISC-V扩展,例如atomic和compressed
- APB3 外设可支持
Sapphire SoC集成了一个32位RISC-V处理器,该处理器具有多达8路的指令缓存和可配置大小的1-32KB,多达8路的数据缓存和可配置大小的1-32KB,4-512KB的片上RAM,以及各种外设(包含1-5 APB3从站外设和1个AXl从站)。您可以在20-400MHZ范围内配置工作频率(实际性能受设计fMAX的限制)。SoC包括1-3个I2C外设、1-3个UART、1-3个用户定时器和1-3个SPI主器件。还具有浮点单元(FPU)、自定义指令接口和Linux内存管理单元 (MMU)
默认配置具有多达256位半双工AXl总线,可与Efinix DDR控制器或HyperRAM控制器进行通信。
- DDR控制器 – 该内核使用Trion FPGA硬DDR DRAM接口来复位外部DRAM模块(重置并重新初始化Trion FPGA的DDR接口以及DDR模块)
- 超 RAM 控制器 – 此内核控制超RAM内存模块 您可以使用 Efinity®软件中的IP管理器自定义SoC
参考资料:
原文地址:https://blog.csdn.net/sqqwm/article/details/134791598
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_40626.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!