rbf文件是Quartus编译生成的fpga配置文件的二进制数据量格式的文件,主要用于使用外部主机通过PS方式配置FPGA。

在含ARM硬核的SoC FPGA中,可以使用HPS配置FPGA,配置时分为两种情况,一种是在HPS处于uboot启动阶段时通过u-boot配置,一种是Linux启动之后通过应用程序配置。这两种配置方式都需要用到rbf格式的配置文件,但是两种方式所需的rbf格式的配置文件却又存在着差异,其中,uboot阶段配置fpga需要使用未经压缩的rbf格式文件,而在Linux应用程序中配置fpga时,需要使用经过压缩了的rbf文件。默认情况下,Quartus软件不能自动生成rbf文件,需要在设置种开启生成rbf文件选项。另外,也可以直接通过命令行的方式,从quartus编译得到的sof文件转换得到rbf文件。图1为在Quartus中直接勾选生成rbf文件的选项。

需要注意的是,这种方式生成的rbf文件是经过压缩了的,可以支持Linux中使用应用程序直接配置FPGA,不支持uboot阶段配置fpga。

另外也可以通过脚本实现

使用sof文件直接转换得到未经压缩的rbf文件的命令格式为:

quartus_cpf -c my_input_file.sof my_output_file.rbf
使用sof文件直接转换得到经过压缩的rbf文件的命令格式为:

quartus_cpf -c -o bitstream_compression=on my_input_file.sof my_output_file.rbf

使用时,可以直接在SoC EDS软件中输入上述命令生成rbf文件,也可以将上述命令做成脚本,这里作者倾向于直接将上述命令做成脚本,然后双击生成rbf文件

打开记事本,将下列命令粘贴到记事本中,然后保存为bat格式。例如保存为“sof2rbf_dc.bat”文件

%QUARTUS_ROOTDIR%\\bin64\\quartus_cpf   -c   -o   bitstream_compression=on  AC501_SoC_GHRD.sof   soc_system_dc.rbf
pause

然后,将sof2rbf_dc.bat文件拷贝到工程中sof所在目录下,直接双击运行该bat文件,就能生成名为soc_system_dc.rbf的文件了,该文件是经过压缩的rbf文件。

同样的再打开记事本,将下列命令粘贴到记事本中,然后保存为bat格式。例如保存为“sof2rbf.bat”文件

%QUARTUS_ROOTDIR%\\bin64\\quartus_cpf   -c   AC501_SoC_GHRD.sof   soc_system.rbf
pause

然后,将sof2rbf.bat文件拷贝到工程中sof所在目录下,直接双击运行该bat文件,就能生成名为soc_system.rbf的文件了,该文件是未经压缩的rbf文件。

注意,上述命令内容中,AC501_SoC_GHRD.sof名字需要换成你工程中实际的sof文件的名字。

下图为分别使用sof2rbf.bat和sof2rbf_dc.bat脚本生成的rbf文件,可以看到,两者尺寸差距较大,soc_system.rbf为4146KB,而soc_system_dc.rbf仅为1270KB。

另外,图中还有一个名为AC501_SoC_GHRD.rbf的文件,该文件是勾选了Quartus的自动生成rbf选项后生成的rbf文件,可以看到,与使用命令方式生成的压缩后的rbf文件尺寸一致。

另外,AC501_SoC_GHRD.sof文件的尺寸比未经压缩的soc_system.rbf文件的尺寸大了440KB,那么这两者之间会有什么联系和区别呢,有兴趣的网友可以研究研究。

 

为Quartus工程生成rbf文件的方法的更多相关文章

  1. vs工程生成dll文件及其调用方法

    转载:https://blog.csdn.net/weixin_44536482/article/details/91519413 vs工程生成dll文件及其调用方法                  ...

  2. 调试SQLSERVER (一)生成dump文件的方法

    调试SQLSERVER (一)生成dump文件的方法 调试SQLSERVER (二)使用Windbg调试SQLSERVER的环境设置调试SQLSERVER (三)使用Windbg调试SQLSERVER ...

  3. Quartus工程中各文件类型的含义

    https://blog.csdn.net/jingliangliu/article/details/52245497 .jic           JTAG Indirect Configurati ...

  4. MDK5生成BIn文件的方法

    配置MDK5 生成bin文件的 第一步:方法打开option for Target 第二步:选择 user 第三步:找到After Build/Rebuild 第四步:勾选run,点击文件选择小图标选 ...

  5. Protel99se生成gerber文件的方法

    这几天工作中遇到制作 gerber 的问题,确实让我郁闷了一 番,为了方便大家,不要再受其苦,特将这一过程写成文档供有这方面需要的同仁们参考. 1 protel99se 打开要生成 gerber 的 ...

  6. Quartus 11生成pof文件在AS烧写之后,程序无法启动

    1. 首先配置成AS,生成.pof文件,选择上面的图标Device 2. 选择Device and Pin Options... 3. 进入配置界面,选择如下 4. 进入下载界面,烧写.pof文件,开 ...

  7. Keil如何生成bin文件【Keil生成Bin文件的方法】

    使用过Keil的同鞋都知道,现在Keil中默认可以输出.axf的调试文件和可以通过钩选输出的.hex可执行文件,没有bin(二进制)文件的输出选项.可是偏偏某些时候需要或者习惯性的使用.bin文件来进 ...

  8. 使用Visual Studio将C#生成DLL文件的方法

    1.命令方式 打开Visual Studio安装目录下的开发人员命令提示 译 File.cs 以产生 File.exe csc File.cs 编译 File.cs 以产生 File.dll csc ...

  9. Ubuntu ./configure 半途终止 导致没有生成makefile文件 解决方法

    在安装thrift的时候,解压包进入目录,执行命令: ./configure 之后,发现某些包没有安装,导致configure到一半的时候退出,接着make发现没有makefile文件.估计是我系统安 ...

随机推荐

  1. scala -- 层级

    层级 层级的顶端是Any 类,定义了如下方法 final def ==(that:Any):Boolean final def !=(that:Any):Boolean def equals(that ...

  2. 疯狂JAVA——第二章 理解面向对象

    面向对象的三大特征:继承.封装和多态 面向对象的方式实际上由OOA(面向对象分析).OOD(面向对象设计)和OOP(面相对象编程)三个部分组成,其中OOA和OOD的结构需要用一个描述方式来描述并记录, ...

  3. zabbix出现中文不能选的情况

    像这里一样,有些选项是选不了的,这个时候我们要做的第一步就是,找到这个配置文件. 如果不知道在哪里的话可以用find命令查找. sudo find / -name locales.inc.php 找到 ...

  4. samtools 的应用

    1)sam转bam samtools view -bS in.sam > in.bam -b 意思使输出使BAM format -S 意思使输入使SAM,如果@SQ 缺剩, 要写-t

  5. 使用ecstore-sdk开发包制作易开店和启明星模板

    前言: 尽管商派官网有模板开发教程,但是诸多方面太过笼统.我等平庸之辈,纵使细心研读,潜心修炼,亦未能品味练功境界,领悟其中真谛. 商派有云,此九阳真经不用您挥刀****本人却感觉此教程令人抓狂,无人 ...

  6. VMware克隆CentOS网络配置

    配置网络 如果是克隆CentOS的: vi /etc/udev/rules.d/70-persistent-net.rules 注释掉网络eth0,把最后一个改为eth0,记录下mac地址. vi / ...

  7. 【校招面试 之 C/C++】第27题 C++ 智能指针(三)之 unique_ptr

    auto_ptr<string> p1(new string ("auto") : //#1 auto_ptr<string> p2; //#2 p2 = ...

  8. django的视图函数介绍

    我们来看下views视图中的函数的request这个变量到底有哪些方法和属性 1.request.path 结果:不包括域名和端口的url路径 2.request.method 结果:这次请求的方法, ...

  9. CentOS设置yum存储库 (nginx)

    要为RHEL / CentOS设置yum存储库,请创建/etc/yum.repos.d/nginx.repo 使用以下内容命名的文件 : [nginx] name=nginx repo baseurl ...

  10. 使用Spring框架来管理模板类

    1. 刚才编写的代码使用的是new的方式,应该把这些类交给Spring框架来管理. 2. 修改的步骤如下 applicationContext.xml中<beans>标签的开头配置为: * ...