首先科普一下

什么是bitstream文件

FPGA比特流(bitstream)是一种用于配置可编程逻辑器件的数据格式,特别是现场可编程门阵列(FPGA)。比特流包含了硬件逻辑电路、路由信息以及芯片上寄存器和存储器(如查找表LUT)的初始值。通常认为比特流具有厂商特定的格式,因此很难反向工程或理解其内部细节。然而,这种观点并不完全正确。

比特流文件不仅仅是一串配置FPGA的位数据,它还包含了一些人类可读的信息字段,用来描述这些位数据。实际上,比特流有一种类似汇编语言的指令集,用以描述FPGA的配置过程。从高层次上看,比特流文件类似于一个可执行程序。与ELF格式的可执行文件类似,比特流也有自己的文件格式来描述内容,而这种格式是公开的,因此可以分析比特流文件的内容,理解配置FPGA的具体步骤。

然而,比特流中未公开的部分在于位映射——即配置位的具体格式,尤其是比特流中的位如何映射到芯片上的具体LUT、连线等资源。可以将此比作,虽然汇编指令能够让你理解某段代码是在进行寄存器上的加法操作,但指令本身并没有明确指出是哪些寄存器参与了运算。

对于大多数FPGA用户而言,了解比特流的内部结构并非必要。只有当你要进行比特流回读、抢占调度或是类似的高级应用时,才需要深入理解比特流的工作原理和格式。例如,在进行比特流回读时,你可能需要验证配置是否正确;在抢占调度中,你可能需要在运行时动态地改变FPGA的部分配置而不影响其余部分的正常工作。

配置文件的格式

UG580 ,可以看到BIN文件相对BIT文件就是少了文件头信息。

参考

https://support.xilinx.com/s/article/14468?language=en_US

http://lastweek.io/fpga/bitstream/

有些开源工程在详细的研究如何去解密bit文件,分析FPGA电路结构,对我们理解bit文件的结构很有价值

bitstream文件结构

如下图所示,0x00-0x80地址区间为文件描述信息,描述该文件对应的器件型号、生成时间等等。

bitstream 可以直接烧录到FLASH吗?

答案是可以,将bit文件重命名为bin文件即可。但是前面不是说bit相对于bin 没有文件头信息吗?也就是说常规烧录到FLASH的bin文件相对于bit要小一些,按道理应该不可以才对,但实际上可以的,为什么呢?

FPGA配置过程SYNC

看一下FPGA的配置过程,尤其是sync 这个步骤。

必须向配置逻辑发送一个特殊的32位同步字(0xAA995566)。这个同步字通知设备即将接收配置数据,并将配置数据与内部配置逻辑对齐。除了总线宽度自动检测序列之外,在同步之前出现在配置输入引脚上的任何数据都将被忽略。 (所以这里即使烧录的文件多了文件头信息也会被忽略掉,这样即使你烧录的是bit文件也是可以的)

在FPGA配置过程中,这个32位的同步字起到关键作用,它标志着配置数据流的开始。配置逻辑在接收到这个特定的同步字后,会准备接收并处理随后到来的比特流数据。这是因为在配置过程中,FPGA的配置逻辑需要知道何时数据流真正开始,以正确地捕获和解释配置信息。如果没有正确的同步,FPGA可能会错误地解析配置数据,导致配置失败或者不正确的功能实现。

总线宽度自动检测序列是一个例外,因为它发生在同步字之前,用于确定配置接口的总线宽度,从而确保后续的数据传输能够正确进行。一旦同步字被识别,FPGA就会根据已知的总线宽度开始接收和解码配置比特流。

https://docs.amd.com/v/u/en-US/ug570-ultrascale-configuration

推荐个小工具 https://hexed.it/ ,如果需要查看bit或者bin的二进制文件,可以在线查看,比较方便

FPGA bit转bin文件的更多相关文章

  1. Zynq系列FPGA如何固化bit文件到QSPI_Flash

    最近由于项目需要,要将bit文件固化到zedboard的flash中,使程序上电自启,断电不丢失. 我们知道,一般板级调试的时候都是直接下载bit流到FPGA就行,固化到Flash的话,也是先生成.m ...

  2. STM32 Unicode 与 GBK 转换 .bin文件放到SD卡是啥意思

    2个数组 : }; }; 一个是Unicode 编码,一个是GBK编码: 用c2b软件转成.bin 二进制文件放到SD卡里: SD卡放入字库 .FON STM32 代码: 代码中SD卡字库和二进制路径 ...

  3. 处理bin文件

    1. fs.Position  写入的位置,从哪个位置开始写 fs.Write(byte1,0,byte1.Length); byte1写入的byte[], 写入内容从第几位开始取,length取多长 ...

  4. JLINK通过JFLASH烧写bin文件报错处理方法

    错误原因:烧写开始地址出错,打开BIN文件后弹出的设置开始地址不正确不能为0 解决措施:用J-FLASH LITE或者将开始地址设置成正确的地址(KEILMDK中IROM1的开始地址

  5. Encrypting bootloader (程序BIN文件加密及在线升级)

    了解更多关于bootloader 的C语言实现,请加我QQ: 1273623966 (验证信息请填 bootloader),欢迎咨询或定制bootloader(在线升级程序). 在上一个博客随笔,我介 ...

  6. C# 读写十六进制bin 文件

    读一个十六进制的bin文件,在bin文件添加四行头,生成新的bin文件.bin文件可以用vs打开查看. using System; using System.Collections.Generic; ...

  7. ubuntu15.10跑裸机程序跑.bin文件

    1:安装tftp:#apt-get update#apt-get install tftp-hpa tftpd-hpa xinetd2:#cd /srv#mkdir tftp#chmod 777 tf ...

  8. 将txt文件数据转成bin文件.

    之前用牛逼的绘图以及分析bmp的像素文件的方法, 整理出汉字编码从: 0x4E00到0x9FA5, (维基上说是9FD5, 完了, 回头再更新吧.) https://en.wikipedia.org/ ...

  9. Keil 4.0 生成bin文件

    在菜单:Flash /configuare falsh tools ... option for Tatget '项目' /User中:在Run User Programs After Build/R ...

  10. TPLink 备份文件bin文件解析

    TPLink 路由器备份文件bin文件 测试路由器 WR885,备份文件加密方式DES,密钥:478DA50BF9E3D2CF linux端: openssl enc -d -des-ecb -nop ...

随机推荐

  1. EasyExcel处理Mysql百万数据的导入导出案例,秒级效率,拿来即用!

    一.写在开头 今天终于更新新专栏 <EfficientFarm> 的第二篇博文啦,本文主要来记录一下对于EasyExcel的高效应用,包括对MySQL数据库百万级数据量的导入与导出操作,以 ...

  2. vscode关于json文件添加注释报错处理

  3. python小功能

    django实现将linux目录和文件名列出来 def index(request): obj=models.USER.objects.all() fileroot = 'd:\machangwei' ...

  4. uniapp 微信支付,小程序支付,支付宝支付问题汇总

    背景介绍 uni-app 可以转微信小程序或直接打包 APP ,支付模块使用统一方法 uni.requestPayment 但是不同平台参数不同容易出现混淆错乱. 相关网站 uni-app 统一支付: ...

  5. OpenOCD + DAP-LINK调试ESP32的失败经历

    目的 手里有调试STM32的DAP-LINK,想试试通过JTAG调试ESP32 OpenOCD支持CMSIS-DAP DAP-LINK支持的芯片,我手上这款描述如下,应该JTAG协议的都支持 平台 w ...

  6. PHP 中使用 ElasticSearch 的最佳实践 (下)

    引言 上一篇文章,我们使用同步的方式将数据,同步写入到 ElasticSearch 中.接下来的这篇文章,主要介绍使用 RabbitMQ 的方式,异步的将数据同步到 ElasticSearch . 部 ...

  7. beego go mod 模式下无法生成注解路由的问题 解决方法

    执行 go get github.com/beego/bee 命令时将bee 命令一定要安装在gopath目录下.有idea或者goland编辑器是最方便的,只需要复制这条命令,然后进入编辑器会提示你 ...

  8. minio-搭建个人云存储服务

    相信风靡全球的亚马逊 AWS S3 的存储云服务大家已经耳熟能详了,如何自己搭建一个私有的S3存储云服务呢?Minio 提供对象存储服务,兼容了 AWS S3 存储协议,用于非结构化的数据存.非结构化 ...

  9. 关于ThreadLocal最直白的解释

    ThreadLocal 底层原理如下: 实线是强引用,虚线是弱引用 Thread 持有 ThreadLocal 对象的引用,ThreadLocalMap 是 Thread 的成员变量,它是一个 Map ...

  10. 你知道键盘是如何工作的吗?(xv6键盘驱动程序)

    键盘驱动程序 公众号:Rand_cs 键盘如何工作的前文曾经说过,当时是以 Linux 0.11 为基础讲的但不系统,本文以 xv6 的键盘驱动程序为例来系统地讲述键盘是如何工作的.关于驱动程序前文磁 ...