【risc-v】易灵思efinix FPGA riscv嵌入式软件源码分享

这篇具有很好参考价值的文章主要介绍了【risc-v】易灵思efinix FPGA riscv嵌入式软件源码分享。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

系列文章目录

分享一些fpga内使用riscv软核的经验,共大家参考。后续内容比较多,会做成一个系列。

本系列会覆盖以下FPGA厂商

  •  易灵思 efinix
  •  赛灵思 xilinx
  •  阿尔特拉 Altera

本文内容隶属于【易灵思efinix】系列。

【risc-v】易灵思efinix FPGA sapphire_soc IP配置参数分享-CSDN博客

【risc-v】易灵思efinix FPGA riscv 时钟配置的一些总结-CSDN博客


目录

系列文章目录

前言

源码文件夹的生成

文件说明

【BSP】

【config】和【config_linux】

【software】

延伸


前言

在efinix fpga中使用riscv是一件相对容易的事,efinix官方提供了一套集成riscv核心的应用IP,在IP catalog中可以很方便的生成、修改。裁剪IP的功能。

上一节我们在efinity IP catalog中选择生成了 riscv IP,在【Deliverables】页可见默认勾选了【embedded_sw】。

本章节就产生的【embedded_sw】进行文件说明。

易灵思 efx_comb4,efinix,fpga开发,risc-v,易灵思,efinix


源码文件夹的生成

IP核生成的同时,会在FPGA工程根目录生成【embedded_sw】文件夹

/embedded_sw/

这个文件夹是 嵌入式软件工程源码文件夹。

易灵思 efx_comb4,efinix,fpga开发,risc-v,易灵思,efinix

我选择是riscv ip是sapphire,因此自动产生【sapphire_soc】文件夹,展开这个文件夹有如下文件夹

易灵思 efx_comb4,efinix,fpga开发,risc-v,易灵思,efinix

文件说明

•nbsp--板级支持包。

•config--适用于Windows系统的Eclipse项目设置文件和OpenOCD调试配置设置文件。

•config_linux--适用于linux系统的Eclipse项目设置文件和OpenOCD调试配置设置文件。

•software——软件示例。

•tool--帮助脚本。

•cpu0.yaml---用于调试的CPU文件。

【BSP】

板级支持包(BSP)定义了地址映射,并与Sapphire SoC硬件地址映射对齐。BSP文件位于nbsp/efinix/EfxSapphireSoC子目录中。

文件或目录

描述

app

示例软件和引导加载程序使用的文件。

include\soc.mk

支持的指令集

include\soc.h

定义系统频率和地址映射

linker\default.ld

主内存地址和大小的链接器脚本。

linker\bootloader.ld

引导加载程序地址和大小的链接器脚本。

openocd

OpenOCD配置文件。

【config】和【config_linux】

Efinix在【config】和【config_linux】文件夹提供了一个C/C++项目设置文件,该文件定义了C代码的包含路径和符号。将这些设置导入到项目中可以让您轻松地浏览和跳过代码。

要导入设置,请执行以下操作:

1。选择“文件”>“导入”打开“导入”向导。

2.展开C/C++。

3.选择“C/C++”>“C/C++项目设置”。

4.单击“下一步”。

5.单击“设置”文件框旁边的“浏览”。

6.转到以下目录,然后单击“打开”:

易灵思 efx_comb4,efinix,fpga开发,risc-v,易灵思,efinix

7。在“选择项目”框中,选择要为其导入设置的项目名称。

8.单击“完成”。

Eclipse在项目中创建一个名为Includes的新文件夹,其中包含项目使用的所有文件。导入设置后,请清理项目(Project > Clean),然后生成(Project> Build Project

)。生成过程对所有文件进行索引,以便将它们链接到项目中。

【software】

Efinix提供了各种示例软件代码,用于执行诸如通过UART通信、控制GPIO中断、执行Dhrystone基准测试等功能。每个示例都包括一个makefile和包含源代码的src目录。

易灵思 efx_comb4,efinix,fpga开发,risc-v,易灵思,efinix

这部分内容很多,下一章节继续。

延伸

---关于易灵思

        易灵思是一家国产FPGA公司,采用逻辑和路由可以互换的XLR结构,发明了突破性的Quantum架构,PPA优势是传统世界领先FPGA公司的4倍。公司从架构与IC设计、工艺制程、封装与测试、成本/品质/交付管控,到EDA工具设计、 IP与应用方案设计、营销与技术支持,均坚持质与量并行,力求问鼎行业桂冠。

---关于risc-v

        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中创建包含嵌入式计算和用户定义加速器的完整系统。

---关于Sapphire SoC

  • VexRiscv处理器,具有5级流水 (读取,解码,执行,内存,回写),中断和机器模式(Machine Mode)的异常处理
  • 20 - 400 MHz 系统时钟频率
  • 4 - 512 KB 带SPI flash引导加载程序的片上RAM
  • DDR或HyperRAM的内存控制器
    • 内存支持4MB - 3.5 GB
    • 用户可配置外部内存总线频率
    • 1个半双工AXI3接口(最高256位),用于外部存储器通信
    • 400 MHz DDR 时钟频率, 800 Mbps数据带宽
    • 200 MHz HyperRAM 时钟频率, 400 Mbps数据带宽
  • 多达2个AXI主通道用于用户逻辑
  • 1 AXI从通道到用户逻辑
  • 包含浮点运算单元
  • 包含一个可选的Linux内存管理单元(MMU)
  • 包含一个具有1024个ID的自定义指令接口,以执行不同的功能
  • 支持可选的RISC-V扩展,例如atomic和compressed
  • APB3 外设可支持
    • 32个 GPIOs
    • 3个 I2C masters
    • PLIC
    • 3个 SPI masters,最高时钟频率 25 MHz — 最多 3个 user timers
    • 3个 UARTs,115,200 baud rate
    • 5个 从外设

Sapphire SoC框图:

易灵思 efx_comb4,efinix,fpga开发,risc-v,易灵思,efinix

        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

参考资料:

产品中心 / RISC-V-易灵思

易灵思

技术支持 / 公开文档-易灵思文章来源地址https://www.toymoban.com/news/detail-804047.html

到了这里,关于【risc-v】易灵思efinix FPGA riscv嵌入式软件源码分享的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • 飞凌嵌入式受邀参加「RISC-V芯片应用交流会」并发表主题演讲

    飞凌嵌入式受邀参加「RISC-V芯片应用交流会」并发表主题演讲

    8月23日下午,在第三届RISC-V中国峰会现场,由赛昉科技主办的「RISC-V芯片应用交流会」吸引了诸多行业伙伴和专家到场参与。此次会议旨在分享赛昉科技高性能RISC-V芯片的软件生态、应用产品、解决方案等全面进展,共同探讨RISC-V芯片的未来发展和挑战,破局RISC-V落地难点。

    2024年02月11日
    浏览(7)
  • RISCV 5 RISC-V调用规则

    RISCV 5 RISC-V调用规则

    RISCV - 1 RV32/64G指令集清单 RISCV - 2 “Zicsr“, CSR Instructions RISCV -3 RV32I/RV64I基本整型指令集 RISCV - 4 ISA 扩展名命名约定 In the RISCV standard ABI, procedures should not modify the integer registers tp and gp, because signal handlers may rely upon their values. 在RISCV标准 ABI 中,函数调用过程不应修改整数寄存器

    2024年02月14日
    浏览(24)
  • RISCV 6 RISC-V加载存储指令

    RISCV 6 RISC-V加载存储指令

    RISCV - 1 RV32/64G指令集清单 RISCV - 2 “Zicsr“, CSR Instructions RISCV -3 RV32I/RV64I基本整型指令集 RISCV - 4 ISA 扩展名命名约定 RISCV 5 RISC-V调用规则 RV32I is a load-store architecture, where only load and store instructions access memory and arithmetic instructions only operate on CPU registers. RV32I provides a 32-bit address s

    2024年02月10日
    浏览(10)
  • RISC-V交叉工具链riscv-gnu-toolchain编译

    注意上面 clone 的仓库,我们称其为构建脚本仓库,其并不包含 gcc 等工具源码,这些源码以 git 的 submodule 的形式作为子仓库的内容发布,所以需要继续更新子仓库。 注意: 使用上诉命令通过 submodule 方式下载困难的话,可以手工通过下载并切换到指定的分支。如 binutils 可通

    2024年02月11日
    浏览(8)
  • 【RISC-V】基于开源RISC-V MCU内核PicoRV32的FPGA移植

    【RISC-V】基于开源RISC-V MCU内核PicoRV32的FPGA移植

    核心板:GW2A-LV18PG256C8IC8I7 底板:Dock底板 有关核心板和底板相关资料的参考网址:Tang Primer 20K - Sipeed Wiki  FPGA硬件设计软件:高云云源软件;下载地址:广东高云半导体科技股份有限公司 PicoRV32描述,以及文档介绍详情见网址PicoRV32 - 高云 - 广东高云半导体科技股份有限公司

    2023年04月09日
    浏览(12)
  • 【基于FPGA的芯片设计】32位RISC-V存储器

    【基于FPGA的芯片设计】32位RISC-V存储器

    实验板卡 :xc7a100tlc sg324-2L,共20个开关 实验要求    

    2024年02月15日
    浏览(11)
  • 在FPGA上运行轻量级Linux系统的RISC-V内核 FPGA开发

    随着嵌入式系统的发展,FPGA(现场可编程门阵列)在实现高性能和灵活性方面发挥着重要作用。RISC-V是一种基于开放指令集架构(ISA)的处理器架构,它在嵌入式系统中越来越受欢迎。本文将介绍如何在FPGA上实现一个轻量级Linux系统,其中包括RISC-V内核的开发。 为了在FPGA上

    2024年02月04日
    浏览(9)
  • RISC-V单板计算机模拟和FPGA板多核IP实现

    🎯使用单板计算机 Visionfive 2 或模拟器测试RISC-V汇编 🎯RISC-V汇编加载和算术。🎯使用GNU MAKE汇编RISC-V指令,ESP32使用CMake编译执行指令。🎯RISC-V汇编功能和使用释义:控制指令,内存管理,功能块和堆栈。 🎯 使用RISC-V汇编代码控制GPIO。🎯RISC-V汇编指令嵌入C 代码,C代码调

    2024年04月12日
    浏览(11)
  • 【基于FPGA的芯片设计】RISC-V的20条指令CPU设计

    【基于FPGA的芯片设计】RISC-V的20条指令CPU设计

    实验板卡 :xc7a100tlc sg324-2L,共20个开关 实验要求:          

    2024年02月16日
    浏览(14)
  • 嵌入式系统中的FPGA

    嵌入式系统中的FPGA

            假设你有一台智能家居系统,其中的FPGA可以被类比为智能家居中的中央控制器。 智能家居系统: 定制家居逻辑: 你希望智能家居系统能够根据你的生活习惯、时间表和喜好自动控制灯光、温度、窗帘等设备。就像FPGA中可以根据需求重新配置硬件逻辑一样,智能

    2024年02月03日
    浏览(12)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包