multiboot远程升级详解

FPGA开发圈 2024-09-05 12:02



Multiboot功能介绍




Multiboot是指多镜像启动,比如在FPGA的加载flash里面存放2个或者多个FPGA的配置文件,每个配置文件都可以单独完成FPGA的逻辑配置,如下图1所示;

图1 multiboot Flash中配置镜像文件的结构
如上图所示,Flash里面包含了Golden Bitstream和Update Bistream,远程升级是指通过网络或者其他远程设备对Flash里面的Update Bistream进行升级,而Golden Bitstream通常是FPGA的基本逻辑版本,主要是实现了升级部分的功能,从应用上要求不管发生什么情况,必须保证Golden Bitstream的完整性,并能够加载FPGA,保证能够通过远程对FPGA进行升级。
通过Multiboot功能我们可以实现使用Golden Bitstream或者Update Bistream对FPGA进行加载,从而在FPGA里面实现Golden Bitstream或者Update Bistream的功能,Update Bistream通常是用户产品实际使用的逻辑功能。




Bitstream文件介绍





Bitstream文件主要包括Header和FPGA逻辑配置数据两部分,如下图2所示:

图2 Bitstream文件结构
其中,Header主要是为FPGA配置起引导作用,FPGA刚上电后会去读取Header的内容并对内容进行分析,从而完成内部逻辑配置,Header的内容由若干条命令组成,如下3图所示:

图3 Header示例
如上图3所示,对于multiboot我们主要关注同步字,timer\WBSTAR\IPROG和Fallback这5个字段:
同步字:标志一个完整配置文件的起始位置,FPGA读取到这个同步字就会认为后面的数据是一个完整的配置文件数据,包括Header和FPGA配置数据;
Timer:设置超时时间的命令,其后面4个字节为超时时间,multiboot提供了加载超时机制,主要是针对Update(用户逻辑)镜像,如果在计数时间内没有完成Update的加载则自动加载Golden镜像;
WBSTAR:指示Update镜像的起始位置,其后面4个字节即为地址值,FPGA会根据该地址去加载Update镜像;
IPROG:Internal PROGRAM,当FPGA检测到该命令后会自动跳到WBSTAR指定的地址加载Update镜像;
Fallback:如果使能了Fallback则在加载Update的过程中如果检测到错误就自动回跳到Golden镜像进行加载;



Multiboot功能实现





上述讲解了配置文件里面的同步字,timer\WBSTAR\IPROG和Fallback这5个字段,Multiboot功能的实现主要就是根据这5个字段来完成,流程图如下图4所示:
图4 multiboot流程图

Step 1:


FPGA上电后自动从flash的0地址开始读取数据,通常Golden镜像的起始地址为0,当FPGA读取到Golden镜像同步字,WBSTAR和IPROG这三个命令后就会自动跳转到Update镜像的起始地址并加载Update镜像,如果Timer命令后面4个字节为非0(说明设置了超时机制)则启动超时机制;


其中WBSTAR,IPROG和Timer可以在VIVADO工程里面进行设置,工程需要先综合并生成bit文件后右键点击Generate Bitstream->点击弹出的Bitstream Settings->进入settings界面后点击Configure additional bitstream settings->点击Configurationg后就可以进行设置了,如下图5所示:

图5 multiboot在VIVADO中的配置
做了图5的配置后,工程的XDC文件会自动增加下面的约束:

重新生成BIT文件后,这些约束的信息就会自动添加到Header里面,如果后续需要修改这些值可以直接在XDC里面修改。

说明:上述multiboot的配置应该在Golden对应的工程里面配置,Update的工程不用配置,因为FPGA上电的时候就是从Golden的Header里面获取这些信息的。当Golden和Update的配置文件都生成后可以通过下面的TCL指令在VIVADO里面直接生成一个MCS文件:

最后直接把生成的MCS文件烧录到flash就可以了。

Setp 2:

检测到WBSTAR和IPROG命令后跳到Update镜像起始地址。

Setp 3:

加载Update镜像。

Setp 4:

如果加载过程中出现如下错误则回跳到Golden镜像加载,如果没有错误就不会走到本步骤。

  • CRC error

  • IDCODE error

  • Watchdog timer time-out error

Setp 5:

加载Golden镜像,如果没有错误就不会走到本步骤。

说明:FPGA一旦检测到IPROG命令则启动Update镜像的加载流程,同时会检测加载过程出现上述列出的CRC,IDCODE和Watchdog timer错误,一旦检测到错误则自动回跳到0地址加载Golden镜像。




远程升级实现




远程升级是指本地设备对终端产品的FPGA程序进行升级,主要是运用了multiboot功能,升级的是flash里面的Update镜像,如下图6所示:
图6 远程设计框图
升级的传输通道可以是以太网\PCIE\USB等总线,那么远程升级主要是解决2个问题,第一个问题是如何把远程设备传输过来的数据通过FPGA写入Flash,第二个问题是如何保证Flash升级功能的完整性,即在任何情况下(比如升级过程中突然断电)要保证Golden镜像的完整性,确保在升级失败的情况下可以从Golden镜像启动重新进行升级。
对于第一个问题,AMD提供了解决方案,提供了通过FPGA写Flash的逻辑代码,包括SpiFlashProgrammer.vhd和SpiSerDes.vhd文件,如下图7所示:
图7 Flash升级逻辑架构
SpiFlashProgrammer.vhd实现了数据接收以及Flash写入数据的流程,SpiSerDes.vhd实现了把SpiFlashProgrammer.vhd模块传输过来的数据转换成SPI的串行数据,并实现SPI读写时序,用户只需要把远程接收数据写入SpiFlashProgrammer.vhd模块即可。

第二个问题,如何保证任何情况下保证Golden镜像的完整性,并能正常从Golden镜像启动。这里会有一个问题,如果Update镜像在升级的过程中遭到损坏可能会导致重新上电后FPGA去加载Update镜像的时候在解析被损坏过的数据包的时候会停止加载,并且不能回跳到Golden镜像加载,这样会导致FPGA无法正常启动和升级。
从上文对multiboot的描述中我们知道FPGA是通过同步字AA995566来找到配置内容,当FPGA上电后从Flash中寻找到Golden镜像的Header同步字的时候就会去分析这个Header,而这个Header包括了WBSTAR和IPROG,会导致FPGA会去加载Update镜像,而如果Update镜像数据包被破坏就有可能会导致FPGA加载失败。
我们的解决方案是把包括WBSTAR和IPROG的Header独立出来,我们称这个Header为multiboot Header,Golden镜像的Header变成正常的不带WBSTAR和IPROG的Header。只要我们保证如果Update镜像没有升级成功的情况下不会寻找multiboot Header,就能保证FPGA不会从Update镜像启动,而是直接从Golden镜像启动。
这个过程我们需要远程升级软件来控制,首先我们把multiboot Header放到flash的第一个扇区,接着放Golden镜像,当软件升级开始的时候先把multiboot Header的内容擦除掉,当升级完成后通过回读flash内Update镜像的数据来确认升级是否成功,如果升级成功,软件就把multiboot Header的内容回写到flash的第一个扇区(由于flash是按照扇区操作的,为了避免擦除multiboot Header的内容的时候影响到其它数据,我们需要把multiboot Header单独放到第一个扇区),如果升级失败则不会回写multiboot Header。因此,如果升级失败(由于突然断电或者其它因素导致),FPGA在上电后就找不到multiboot Header,然后就会直接往下寻找到Golden镜像,就会直接加载Golden镜像。

我们需要注意的是升级软件任何时候都只对multiboot Header和Update镜像进行操作,不能操作Golden镜像的内容,保证Golden镜像的完整性。Flash内容结构以及启动流程如下图8所示:

Multiboot header主要是包括了同步字AA995566,WBSTAR和IPROG命令,FPGA启动加载时会按照如下步骤:

Step 1:从0地址读取Multiboot header;

Step 2:如果读取到正常的Multiboot header则跳转的Update镜像进行加载;

Step 3;如果读取不到正常的Multiboot header则直接加载Golden镜像;


如果您对此文章有疑问,欢迎联系:

simonyang@comtech.cn

charlesxu@comtech.cn


【预约直播】

FPGA开发圈 这里介绍、交流、有关FPGA开发资料(文档下载,技术解答等),提升FPGA应用能力。
评论 (0)
  • 文/郭楚妤编辑/cc孙聪颖‍相较于一众措辞谨慎、毫无掌舵者个人风格的上市公司财报,利亚德的财报显得尤为另类。利亚德光电集团成立于1995年,是一家以LED显示、液晶显示产品设计、生产、销售及服务为主业的高新技术企业。自2016年年报起,无论业绩优劣,董事长李军每年都会在财报末尾附上一首七言打油诗,抒发其对公司当年业绩的感悟。从“三年翻番顺大势”“智能显示我第一”“披荆斩棘幸从容”等词句中,不难窥见李军的雄心壮志。2012年,利亚德(300296.SZ)在深交所创业板上市。成立以来,该公司在细分领
    华尔街科技眼 2025-05-07 19:25 444浏览
  • 硅二极管温度传感器是一种基于硅半导体材料特性的测温装置,其核心原理是利用硅二极管的电学参数(如正向压降或电阻)随温度变化的特性实现温度检测。以下是其工作原理、技术特点及典型应用:一、工作原理1、‌PN结温度特性‌硅二极管由PN结构成,当温度变化时,其正向电压 VF与温度呈线性负相关关系。例如,温度每升高1℃,VF约下降2 mV。2、‌电压—温度关系‌通过jing确测量正向电压的微小变化,可推算出环境温度值。部分型号(如SI410)在宽温域内(如1.4 K至475 K)仍能保持高线性度。
    锦正茂科技 2025-05-09 13:52 256浏览
  • 在过去的很长一段时间里,外卖市场呈现出美团和饿了么双寡头垄断的局面。美团凭借先发优势、强大的地推团队以及精细化的运营策略,在市场份额上长期占据领先地位。数据显示,截至2024年上半年,美团外卖以68.2%的市场份额领跑外卖行业,成为当之无愧的行业老大。其业务广泛覆盖,从一线城市的繁华商圈到二三线城市的大街小巷,几乎无处不在,为无数消费者提供便捷的外卖服务。饿了么作为阿里本地生活服务的重要一环,依托阿里强大的资金和技术支持,也在市场中站稳脚跟,以25.4%的份额位居第二。尽管市场份额上与美团有一定
    用户1742991715177 2025-05-06 19:43 116浏览
  • UNISOC Miracle Gaming奇迹手游引擎亮点:• 高帧稳帧:支持《王者荣耀》等主流手游90帧高画质模式,连续丢帧率最高降低85%;• 丝滑操控:游戏冷启动速度提升50%,《和平精英》开镜开枪操作延迟降低80%;• 极速网络:专属游戏网络引擎,使《王者荣耀》平均延迟降低80%;• 智感语音:与腾讯GVoice联合,弱网环境仍能保持清晰通话;• 超高画质:游戏画质增强、超级HDR画质、游戏超分技术,优化游戏视效。全球手游市场规模日益壮大,游戏玩家对极致体验的追求愈发苛刻。紫光展锐全新U
    紫光展锐 2025-05-07 17:07 340浏览
  • 飞凌嵌入式作为龙芯合作伙伴,隆重推出FET-2K0300i-S全国产自主可控工业级核心板!FET-2K0300i-S核心板基于龙芯2K0300i工业级处理器开发设计,集成1个64位LA264处理器,主频1GHz,提供高效的计算能力;支持硬件ECC;2K0300i还具备丰富的连接接口USB、SDIO、UART、SPI、CAN-FD、Ethernet、ADC等一应俱全,龙芯2K0300i支持四路CAN-FD接口,具备良好的可靠性、实时性和灵活性,可满足用户多路CAN需求。除性价比超高的国产处理器外,
    飞凌嵌入式 2025-05-07 11:54 97浏览
  • 二位半 5线数码管的驱动方法这个2位半的7段数码管只用5个管脚驱动。如果用常规的7段+共阳/阴则需要用10个管脚。如果把每个段看成独立的灯。5个管脚来点亮,任选其中一个作为COM端时,另外4条线可以单独各控制一个灯。所以实际上最多能驱动5*4 = 20个段。但是这里会有一个小问题。如果想点亮B1,可以让第3条线(P3)置高,P4 置低,其它阳极连P3的灯对应阴极P2 P1都应置高,此时会发现C1也会点亮。实际操作时,可以把COM端线P3设置为PP输出,其它线为OD输出。就可以单独控制了。实际的驱
    southcreek 2025-05-07 15:06 555浏览
  • 这款无线入耳式蓝牙耳机是长这个样子的,如下图。侧面特写,如下图。充电接口来个特写,用的是卡座卡在PCB板子上的,上下夹紧PCB的正负极,如下图。撬开耳机喇叭盖子,如下图。精致的喇叭(HY),如下图。喇叭是由电学产生声学的,具体结构如下图。电池包(AFS 451012  21 12),用黄色耐高温胶带进行包裹(安规需求),加强隔离绝缘的,如下图。451012是电池包的型号,聚合物锂电池+3.7V 35mAh,详细如下图。电路板是怎么拿出来的呢,剪断喇叭和电池包的连接线,底部抽出PCB板子
    liweicheng 2025-05-06 22:58 638浏览
  • 温度传感器的工作原理依据其类型可分为以下几种主要形式:一、热电阻温度传感器利用金属或半导体材料的电阻值随温度变化的特性实现测温:l ‌金属热电阻‌(如铂电阻 Pt100、Pt1000):高温下电阻值呈线性增长,稳定性高,适用于工业精密测温。l ‌热敏电阻‌(NTC/PTC):NTC 热敏电阻阻值随温度升高而下降,PTC 则相反;灵敏度高但线性范围较窄,常用于电子设备温控。二、热电偶传感器基于‌塞贝克效应‌(Seebeck effect):两种不同
    锦正茂科技 2025-05-09 13:31 245浏览
  • 后摄像头是长这个样子,如下图。5孔(D-,D+,5V,12V,GND),说的是连接线的个数,如下图。4LED,+12V驱动4颗LED灯珠,给摄像头补光用的,如下图。打开后盖,发现里面有透明白胶(防水)和白色硬胶(固定),用合适的工具,清理其中的胶状物。BOT层,AN3860,Panasonic Semiconductor (松下电器)制造的,Cylinder Motor Driver IC for Video Camera,如下图。TOP层,感光芯片和广角聚焦镜头组合,如下图。感光芯片,看着是玻
    liweicheng 2025-05-07 23:55 460浏览
  • Matter协议是一个由Amazon Alexa、Apple HomeKit、Google Home和Samsung SmartThings等全球科技巨头与CSA联盟共同制定的开放性标准,它就像一份“共生契约”,能让原本相互独立的家居生态在应用层上握手共存,同时它并非另起炉灶,而是以IP(互联网协议)为基础框架,将不同通信协议下的家居设备统一到同一套“语义规则”之下。作为应用层上的互通标准,Matter协议正在重新定义智能家居行业的运行逻辑,它不仅能向下屏蔽家居设备制造商的生态和系统,让设备、平
    华普微HOPERF 2025-05-08 11:40 391浏览
  • 随着智能驾驶时代到来,汽车正转变为移动计算平台。车载AI技术对存储器提出新挑战:既要高性能,又需低功耗和车规级可靠性。贞光科技代理的紫光国芯车规级LPDDR4存储器,以其卓越性能成为国产芯片产业链中的关键一环,为智能汽车提供坚实的"记忆力"支持。作为官方授权代理商,贞光科技通过专业技术团队和完善供应链,让这款国产存储器更好地服务国内汽车厂商。本文将探讨车载AI算力需求现状及贞光科技如何通过紫光国芯LPDDR4产品满足市场需求。 车载AI算力需求激增的背景与挑战智能驾驶推动算力需求爆发式
    贞光科技 2025-05-07 16:54 229浏览
我要评论
0
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦