0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

FPGA的重构是什么,具有哪些要点

OpenFPGA 来源:OpenFPGA 作者:OpenFPGA 2021-07-02 17:39 次阅读

“重构”对于刚接触FPGA的人来说,可谓十分神秘,对于已经入门的人来说很“简单”,但是你真的了解FPGA的重构吗?

术语“重构”是指FPGA已经配置后的重新编程。FPGA的重构有两种类型:完全的和部分的。完全重构将整个FPGA重新编程,而部分重构只取代设计的一部分,设计的剩下部分仍正常工作。部分重构不被视为完全重构的特殊情况,因为两者基本相同。对FPGA执行部分重构通过使用与完全重构(JTAG、CAP或SelectMAP接口)相同的方法来进行,如上一节所述。比特流的结构对于完全和部分重构来说都是相同的。

FPGA重构具有以下几个优点。它允许多个设计共享同一个FPGA架构,这反过来又降低了FPGA的面积、成本和系统复杂性。完全和部分重构为许多FPGA的创新应用程序提供了可能,否则,高昂的成本将影响应用程序实现。利用FPGA重构优势的一些应用如DSP音频视频处理器等,它们根据用户输人,由包括集成深度包检测通信控制器修改处理算法,以改变基于协议的数据包处理器。很多工业和学术性的FPGA重构方面的研究不断产生有价值的应用、研究论文和学位论文。

虽然部分重构技术不是一项新功能,也不是主流的研究方向,但是设计和实现流程、工具支持甚至名词术语都在不断发展,用户界面越来越友好。最终目标是向FPGA开发者提供简单和透明的设计流程,无须详细了解配置逻辑和比特流结构。部分重构是一项复杂过程,在设计实现、工具流程和重构本身的过程中充斥着多重挑战。面临的一个挑战是在FPGA配置的变化过程中,完成平滑切换而无须中断剩余设计功能或损害其完整性。而在完全重构过程中,FPGA架构和10不能保持在复位。另一项挑战是在改变过程中,防止设计的未改动部分进入无效状态。设计者必须正确界定和约束未改动和改动部分之间的接口。这样,FPGA物理实现工具才能进行配置并使用完全相同的布线资源。

有三个部分重构流程可用于Xilinx FPGA基于差异的(difference based)、基于分层的(partition based)及使用动态重构端口。基于差异的部分重构基于差异的部分重构[2]最适合用于将小型设计转化为LUT方程、IO特征和BRAM中的内容。以下是一个简单的、基于差异的部分重构代码和流程举例,它可以运行在Xilinx开发板上。

//原始模块:当两个按钮都按下时,点亮LED

module top(input btn0,btnl,output led); assign led=btn0&btnl;endmodule//top

//部分重构模块:当两个按钮之一按下时,点亮LEDbutton is pressed

module top_pr(input btn0,btn1,output led); assign led=btn0 | btn1;endmodule//top_pr

#约朿文件:对两个设计都相同

NET “btnO” LOC= “A18” ;NET “btnl” LOC= “H17” ;NET “led” LOC= “AD21”;

#实现LED功能的LUT被锁定到特定逻辑片中#对于原始设计,LUT函数是btn0 & btn1#对于部分重构设计,LUT函数是btn0|btn1

INST “led” AREA_GROUP=“led”;AREA_GROUP “led” RANGE = SLICE_X65Y168:SLICE_X65Y168;

#bitgen命令用于产生部分重构比特流#ActiveReconfig和Persist选项在配置变化期间置为全局复位

$bitgen -g ActiveReconfig:Yes -g Persist:Yes -r top_orig.bittop_pr.ncd top_pr.bittop_orig.bit:原始设计的比特流top_pr.ncd:部分重构设计的布局布线后输出top_pr.bit:得到的部分重构比特流结果

上面例子中基于差异的部分重构流程包括以下步骤:

(1)编译top模块。结果是比特流文件top_orig.bit。(2)编译top_pr模块。结果是布局布线后文件top_pr.ncd。(3)使用top.orig.bit比特流和top_pr.ncd,生成包含两个设计之间LED LUT方程差异的比特流。

基于分层的部分重构

与基于差异的重构不同,基于分层的部分重构流程支持重构大型部件FPGA设计。PlanAhead工具它提供了用于配置、实现和使用分层管理部分重构项目的集成环境。设计和实现流程的简要概述如下所示

:•FPGA开发者指定待配置的部分设计

•在FPGA芯片上包含所需逻辑、嵌入式存储器、10和其他资源的区域。•开发者定义覆盖该区域的所有可能设计变量。

•PlanAhead工具管理所有诸如编译设计的细节,包括管理多个网表、静态的和可重构的设计部分,执行DRC,并产生合适的比特流。

Xilinx应用提示XAPP883提供了使用部分重构的示例,以允许嵌入式PCI Exress接口模块的快速配置。

动态重构端口

改变Xilinx GTX收发器、混合模式时钟管理器(MMCM)和System Monitor原语设置的另一种方法,是使用动态重构端口(DRP)DRP提供了一个简单的用户逻辑接口,不需要更多地了解配置寄存器和比特流结构。例如,DRP允许输出时钟频率、相位和MMCM的占空比动态变化。

文章出处:【微信公众号:OpenFPGA】

责任编辑:gt


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • FPGA
    +关注

    关注

    1598

    文章

    21265

    浏览量

    592744
  • 控制器
    +关注

    关注

    112

    文章

    15132

    浏览量

    170831
  • 接口
    +关注

    关注

    33

    文章

    7603

    浏览量

    148355

原文标题:FPGA 的重构

文章出处:【微信号:Open_FPGA,微信公众号:OpenFPGA】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    fpga芯片的主要特点包括 fpga芯片上市公司

    具有显著优势,特别适用于实时性要求高的应用场景。 设计灵活与可重构性:FPGA芯片属于硬件可重构的芯片结构,其内部设置了数量丰富的输入输出单元引脚及触发器。这种灵活性使得
    的头像 发表于 03-14 16:46 202次阅读

    FPGA设计需要掌握的四大核心要点

    CPU core:分为2种,软core和硬core.软core是用逻辑代码写的CPU模块,可以在任何资源足够的FPGA中实现,使用非常灵活。而且在大容量的FPGA中还可以集成多个软core,实现多核并行处理。
    发表于 03-14 11:36 152次阅读
    <b class='flag-5'>FPGA</b>设计需要掌握的四大核心<b class='flag-5'>要点</b>

    fpga是什么 fpga用什么编程语言

    FPGA(Field-Programmable Gate Array)是一种可编程逻辑技术,它使用可重构的硬件单元(如门阵列和查找表)来实现电路功能。相比传统的专用集成电路(ASIC),FPGA
    的头像 发表于 02-04 15:26 432次阅读

    FPGA与GPU的区别

    和GPU之间的区别。 架构: FPGA是一种可编程逻辑器件,它由一系列可编程的逻辑单元(LOOKUP表和寄存器)组成,并通过可编程的互连网络进行连接。这使得FPGA具有高度的灵活性和可重构
    的头像 发表于 12-25 15:28 905次阅读

    防浪涌时,PCB布线有哪些要点

    防浪涌时,PCB布线有哪些要点
    的头像 发表于 12-05 15:34 478次阅读
    防浪涌时,PCB布线有哪些<b class='flag-5'>要点</b>?

    fpga是什么?看完你就明白了

    单元(如逻辑门、触发器等)和可编程连线资源的集成电路芯片。与传统的固定功能芯片不同,FPGA具有动态可重构的特性,可以根据用户需求进行各种不同的配置。 二:FPGA的工作原理
    发表于 11-13 15:43

    FPGA算法映射要点

    将图像处理的算法转换为FPGA系统设计的过程称为算法映射,CPU并行算法的实现与FPGA并行算法的实现是有一定区别的。1.算法系统结构 图像处理算法主要有两种设计结构:流水线结构和并行阵列结构
    的头像 发表于 09-11 10:45 303次阅读
    <b class='flag-5'>FPGA</b>算法映射<b class='flag-5'>要点</b>

    FPGA的可重构测控系统应用设计的研究

    本文根据测控系统的通用结构模型和FPGA的可重构功能特点,提出了一种基于FPGA器件,针对嵌入式应用有效缩短开发周期和设计与应用成本,满足并行性、多任务、开放化和集成化要求的RMS的平台式设计思想,实现了测控系统“只能由厂家定义
    的头像 发表于 08-25 15:49 406次阅读

    代码重构的经验总结

    具体的重构手段可参考《代码大全2》或《重构:改善既有代码的设计》,本文不再班门弄斧,而侧重重构时一些粗浅的“方法论”,旨在提高重构效率。
    的头像 发表于 08-23 10:10 310次阅读
    代码<b class='flag-5'>重构</b>的经验总结

    kv260采用的FPGA型号是什么?

    重构电路芯片,可以根据需要重新编程为不同的电路配置。FPGA具有逻辑门、存储单元、时序控制单元和输入/输出接口等功能单元,可以用于高速数据处理、数字信号处理、嵌入式系统设计、图像处理等领域。KV260
    的头像 发表于 08-16 11:15 792次阅读

    简单了解FPGA重构技术

    FPGA重构技术就是通过上位机控制在FPGA运行过程中加载不同的Bitstream文件,FPGA芯片根据文件内的不同逻辑将内部的资源全部或部分进行重新配置以达到多种功能任务动态切换的
    发表于 08-04 10:08 398次阅读

    SLMLET,具有混合RISC-V内核,高速IF和eFPGA的S

    SLMLET,具有混合RISC-V内核,高速IF和eFPGA的SoC 演讲ppt分享
    发表于 07-17 16:34 2次下载

    详解电机控制中的电压重构

    导读:本期文章主要介绍电机控制中的电压重构重构的电压用于磁链估计等模块必须的输入,对整体控制而言,显得尤为重要。
    发表于 07-15 11:32 1365次阅读
    详解电机控制中的电压<b class='flag-5'>重构</b>

    FPGA 的结构图及优势分析

    FPGA 名为现场可编程门阵列,是一种硬件可重构的集成电路芯片,现场可编程性是FPGA的最大特点。
    发表于 05-11 11:28 772次阅读
    <b class='flag-5'>FPGA</b> 的结构图及优势分析

    FPGA设计的4大要点盘点

      早期的FPGA相对比较简单,所有的功能单元仅仅由管脚、内部buffer、LE、RAM构建而成,LE由LUT(查找表)和D触发器构成,RAM也往往容量非常小。
    发表于 05-09 11:22 181次阅读