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

news2024/11/17 21:49:02

系列文章目录

分享一些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】进行文件说明。


源码文件夹的生成

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

/embedded_sw/

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

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

文件说明

•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.转到以下目录,然后单击“打开”:

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

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

        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框图:

图片

        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-易灵思

易灵思

技术支持 / 公开文档-易灵思

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1295152.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

若依框架的搭建

若依框架 若依框架的搭建(前后端分离版本)环境要求IDEA拉取Gitee源码Mysql 配置Redis 配置后端启动前端配置问题解决 效果展示 若依框架的搭建(前后端分离版本) 简介 RuoYi-Vue 是一个 Java EE 企业级快速开发平台,基…

ssh安装及问题解决

ssh安装及遇到的问题 ssh分为客户端 openssh-client 和服务器 openssh-server,可以利用以下命令确认是否安装: dpkg -l | grep ssh我用ubantu安装的,所以默认安装了客户端 安装客户端和服务器端的命令分别为: sudo apt-get ins…

LLM时代,数据为王,19个开源数据集下载网站汇总

大模型时代,数据为王,在哪里寻找开源数据集,是一个比较头疼的问题。经过调研整理,下面列出了目前可以寻找开源大模型数据集的网站清单。 1、HuggingFace开源数据集 链接:https://huggingface.co/datasets 镜像&#…

TSINGSEE青犀智能商场远程视频监控方案,助力商场统一智能化监管

随着经济的发展和人们物质生活的提高,商场的普及度也越来越高,而商场一般都有占地面积大、人流量多、人员复杂的特点,商场的统一化管理也是一个大问题。智能商场远程视频监控通过利用物联网和云计算技术,可以用来实现远程统一化视…

【若依框架实现上传文件组件】

若依框架中只有个人中心有上传图片组件&#xff0c;但是这个组件不适用于el-dialog中的el-form表单页面 于是通过elementui重新写了一个上传组件&#xff0c;如图是实现效果 vue代码 <el-dialog :title"title" v-model"find" width"600px"…

代码随想录第二十七天(一刷C语言)|分发饼干摆动序列最大子数组和

创作目的&#xff1a;为了方便自己后续复习重点&#xff0c;以及养成写博客的习惯。 一、分发饼干 思路&#xff1a;参考carl文档 局部最优就是大饼干喂给胃口大的&#xff0c;充分利用饼干尺寸喂饱一个&#xff0c;全局最优就是喂饱尽可能多的小孩。尝试使用贪心策略&#x…

[Firefly-Linux] RK3568 pca9555芯片驱动详解

文章目录 一、PAC9555 介绍二、ITX-3568JQ PAC9555 使用2.1 原理图2.2 设备树三、RK3568 I2C 介绍四、PAC9555 驱动4.1 介绍4.2 数据结构4.3 驱动分析一、PAC9555 介绍 PAC9555 是一种高性能、低功耗 I/O 扩展芯片,能够提供 16 个 GPIO 通道,每个通道可以单独配置为输入或输…

基于深度学习的钢铁缺陷检测系统(含UI界面,Python代码,数据集、yolov8)

项目介绍 项目中所用到的算法模型和数据集等信息如下&#xff1a; 算法模型&#xff1a;     yolov8 yolov8主要包含以下几种创新&#xff1a;         1. 添加注意力机制&#xff08;SE、CBAM等&#xff09;         2. 修改可变形卷积&#xff08;DySnake-主干c…

SRR参考设计中SRR_DSS_mmWaveTask函数源码分析

相应的说明都已注释的形式写出来。 上面两个中断是在初始化的时候注册的&#xff0c;在SRR_DSS_initTask函数中&#xff0c;如下所示 后面会接着分析函数MmwDemo_processChirp和MmwDemo_interFrameProcessing。

寒冬不再寒冷:气膜体育馆如何打造温馨运动天地

取暖季即将来临&#xff0c;随着气温逐渐下降&#xff0c;人们在寒冷的冬季里如何保持运动热情和身体的健康成为了一项挑战。而在这个时候&#xff0c;气膜体育馆成为了运动爱好者们的理想场所&#xff0c;提供如春般温暖舒适的运动环境。那么&#xff0c;让我们一起揭秘气膜体…

树根互联如何建造灯塔“灯塔工厂”?

一、项目背景:经历了行业周期阵痛,三一下决心通过智能制造来降本增效 关键点1:内部-制造业市场多变 (1)制造业8年或10年一个经营低谷周期; (2)市场变化巨大,如何快速高效应对; 关键点2:外部-市场快速发展紧逼 (1)通过向先进工厂对比,发现自身不足; (2)通过…

应用架构——集群、分布式、微服务的概念及异同

一、什么是集群&#xff1f; 集群是指将多台服务器集中在一起&#xff0c; 每台服务器都实现相同的业务&#xff0c;做相同的事&#xff1b;但是每台服务器并不是缺 一不可&#xff0c;存在的主要作用是缓解并发能力和单点故障转移问题。 集群主要具有以下特征&#xff1a; …

IP地址定位技术:追踪位置、识别风险

随着互联网的普及&#xff0c;IP地址定位技术逐渐成为网络安全领域的一项重要工具。通过追踪IP地址位置&#xff0c;可以识别潜在的风险用户&#xff0c;加强网络安全。本文将深入研究IP地址定位技术的原理、应用以及相关的风险与防范。 1. IP地址定位技术的原理&#xff1a; …

基于微群机器人的二次开发

请求URL&#xff1a; http://域名地址/modifyGroupName 请求方式&#xff1a; POST 请求头Headers&#xff1a; Content-Type&#xff1a;application/jsonAuthorization&#xff1a;login接口返回 参数&#xff1a; 参数名必选类型说明wId是String登录实例标识chatRoom…

VUE学习二、创建一个前端项目

1.创建一个vue项目 使用命令 vue ui启动vue脚手架 vue ui 等待项目创建好 可以来任务栏启动项目 参数那里可以设置启动端口等参数 启动成功 成功访问 2. 用webstorm 打开项目 脚手架页面可安装基本依赖 比如路由 使用ws打开项目 启动项目 npm run serve 3.修改启动…

SpringAOP专栏一《使用教程篇》

在b站跟着黑马程序员学习SpringAOP时记的笔记。 面向切面编程AOP是 Spring的两大核心之一。 AOP概述 AOP是什么 AOP英文全称&#xff1a;Aspect Oriented Programming&#xff08;面向切面编程、面向方面编程&#xff09;&#xff0c;其实说白了&#xff0c;面向切面编程就是…

《算法通关村——盘点面试大热门之区间问题》

《算法通关村——盘点面试大热门之区间问题》 LeetCode252 给定一个会议时间安排的数组 intervals &#xff0c;每个会议时间都会包括开始和结束的时间 intervals[i] [starti, endi] &#xff0c;请你判断一个人是否能够参加这里面的全部会议。 示例 1:&#xff1a; 输入: …

2024年SEO策略:如何优化您的知识库?

如今很多人在遇到问题时都会求助于谷歌。谷歌已经成为提供解决方案不可或缺的工具。作为全球搜索引擎的巨头&#xff0c;拥有大量用户流量。这就是为什么确保您的产品和服务在谷歌搜索结果中排名靠前是至关重要的&#xff0c;如果您想获得更多的客户&#xff0c;SEO是一个非常关…

IC入门必看| 数字IC前端设计学习路线与方法(内附学习视频)

众所周知&#xff0c;数字前端设计对于工程师的能力要求比较高&#xff0c;不仅有学历上的要求&#xff0c;还要求掌握很多的知识技能。 数字前端到底是什么&#xff1f; 集成电路设计&#xff08;Integrated Circuit&#xff0c;简称IC&#xff09;一般分为数字IC设计、模拟…

NestJs的基础使用

初始化项目 创建项目 // 安装脚手架(只需要安装一次,因为这个是全局的) npm i -g nestjs/cli // 创建项目 nest new project-name // (该过程有个选择包管理工具的,我选的yarn)启动项目 yarn run start:dev // 可以在浏览器访问localhost:3000 输出helloWorld控制器和路由 …