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

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

3天内不再提示

基于PCIE(mcap)的部分可重构实现方案

电子设计 来源:CSDN 博主 作者:向前行 2021-01-03 09:20 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

本博文主要是对基于PCIE(mcap)的部分可重构实现的步骤做一个简单的演示,如有错误之处,欢迎批评指正。值得说明的是,基于PCIE的部分可重构需在ultrascale系列及ultrascale+芯片才能实现,具体哪些系列能实现哪种配置方式如下图所示:

o4YBAF9uJsSADE5RAAFmTD1i1do111.png

图1

本质上来说,无论是JTAG还是ICAP或者MCAP以及其它FPGA的配置方式,目的都是配置FPGA的逻辑。MCAP是通过PCIE来实现对FPGA的烧写,最终结果和使用JTAG进行FPGA烧写没有区别,而使用PCIE对FPGA烧写有更好的灵活性,在某些需求场合是必不可缺的,譬如在数据加速的部署,FPGA加速板卡是位于服务器端,在服务上线之后修改FPGA业务逻辑的话如果使用JTAG烧写,一方面操作十分不便,可行性极低,另一方面,重新烧写FPGA会导致原FPGA的PCIE设备从服务器中删除,需要重新启动服务器枚举设备(目前本人没有找到可以进入系统后重新枚举设备的方法),对于已经上线的服务器,在每次切换FPGA业务逻辑后重启服务器是无法接受的,因此,使用PCIE对FPGA的部分重配置就十分必要,部分重配置能够在保持FPGA静态逻辑(PCIE部分和其他非业务逻辑)正常工作的情况下动态修改某个区域的逻辑(业务逻辑)。使用这种技术能够不重启服务器情况下快速切换业务逻辑。

本文的实现基于Xilinx的VCU1525加速板卡实现,VCU1525的FPGA是一颗ultrascale+的VU9P,由上图可以知道UltraScale+系列的FPGA支持MCAP配置模式。下面由一个简单的例程实现MCAP部分重配置。

1.新建一个空白工程。

o4YBAF9uJsaAT3qxAAEIahP0tvk791.png

图2

2.因为使用MCAP的配置方式,而MCAP集成于PCIE硬核中,因此需要例化一个PCIE相关的IP,这里使用XDMA进行本次例程(裸PCIE硬核也可以),该例程没有XDMA进行数据DMA搬运的相关内容,仅仅是借用XDMA中的MCAP功能,本人目前也有一个比较痛苦的地方,就是XDMA的上位机驱动怎么和MCAP的驱动整合在一起,不懂上位机驱动开发表示很迷茫,有大佬懂这个可以探讨下。

3.在Board选项中(在建立工程时选择Xilinx官方板卡才有这个选项)选择如下。

pIYBAF9uJseAWkrKAACwWZmMLXU305.png

图3

4.在Basic选项中,把图中红色框中的Mode设置成Advanced。

pIYBAF9uJsmAJfrsAAEHcKEsmbc366.png

图4

5.在Basic选项中,在最底部的Tandem Configuration or Partial Reconfiguration中选择PR over PCIE。

o4YBAF9uJsuAeXFVAAED12L25Fo564.png

图5

6.在Pcie ID选项的Device ID中设置成8011(因为Xilinx提供的驱动支持8011,8038,506F)

pIYBAF9uJsyADitNAADp_pK0xfE244.png

图6

7.其它按照默认选项,生成该IP。

pIYBAF9uJs6AKeWaAACQPZzfmtk607.png

图7

8.考虑到测试和实现的方便,使用XDMA的Example Design来修改例程,在XDMA综合完成之后(记得选择OOC),打开该IP的Example Design,在该工程上面做修改。

o4YBAF9uJs-Ad90sAACHcewbYo8071.png

图8

9.Example Design如下图。

o4YBAF9uJtGAP0lPAAEX9FDHH8o425.png

图9

10.首先我们先修改XDC文件和工程顶层,主要是LED的管脚和电平约束。在这个例子中,我们将要实现使用两个可重构模块,一个模块用于控制VCU1525的LED灯亮,一个模块用于控制VCU1525的LED灯灭,用这个简单的例子来说明PR的实现步骤。

11.修改工程中的时钟生成IP,此步骤不是必要,主要是指定输入时钟管脚,如果不是官方板子,在XDC里面约束即可。

pIYBAF9uJtKAI2D-AAA6agzhgkM642.png

图10

12.新建两个模块,分别是LED_RM_0和LED_RM_1。其中LED_RM_0用于控制LED灭,LED_RM_1用于控制LED亮。两个模块的逻辑很简单,只是做演示作用。代码逻辑如下。

pIYBAF9uJtOAegZLAAAUfYudRF0028.png

图11

13.在工程顶层例化其中一个RM模块。

o4YBAF9uJtSAJX3JAABZFo0qvpQ903.png

图12

14.完成上述步骤之后,选择Tools->Enable Partial Reconfiguration...选项,将工程转换成支持PR类型的工程,在后续弹出的方框中选择Convert。

pIYBAF9uJtaAK-zeAAGnqGdlWto916.png

图13

15.此时工程已经转换完成,对比转换之前,在Flow Navigator的PROJECT MANAGER会多出Partial Reconfiguration Wizard选项。

o4YBAF9uJtiARhkeAAHXfHmWZEI331.png

图14

16.设置我们要进行部分重构的逻辑,即LED_RM_x模块,如下图所示,右键LED_RM_0,选择Create Partition Definition...

o4YBAF9uJtqADs_JAAJLfvq1YPM045.png

图15

17.在弹出的窗口中指定一个分区的名字,这里设置为LED_RM,点击OK。

pIYBAF9uJtyACGCEAABr514vhIw718.png

图16

18.完成上一步之后,LED_RM_0模块变成了一个黄色的棱形标志,如下图所示。

o4YBAF9uJt2ABxcAAABDX9vSgG4805.png

图17

19.打开Partial Reconfiguration wizard

pIYBAF9uJt-AOUEBAAENY1caBLY838.png

图18

20.在Edit Reconfiguration Modules界面中,点击“+”符号,把LED_RM_1添加进来,表明有两个重配置模块,添加完成后如下图所示,属于LED_RM分区定义列表里面有LED_RM_0和LED_RM_1两个重配置模块。

o4YBAF9uJuCALcBDAACuSoPOiGs491.png

图19

21.在Editing Configurations界面中,选择automatically create configurations,并修改Configuration Name,如下图所示。

pIYBAF9uJuGAOFjkAACwvEzVmTs034.png

图20

22.在Edit Configuration Runs界面中,选择automatically create configurations。

o4YBAF9uJuOAJncQAADab9KkXMo510.png

图21

23.最后,点击Finish,部分重配置的向导设置完成,然后点击Run Synthesis综合设计。

pIYBAF9uJuWABGFKAAKUBpw9QmY674.png

图22

24.综合完成之后打开综合设计。

o4YBAF9uJueAB1mxAABLkjIWfhM374.png

图23

25.在Floorplanning界面,右键LED_RM_0,选择Floorplanning->Draw Pblock,给RM模块划分重配置的区域。

o4YBAF9uJumATQ2SAAFLFf2Cq_0987.png

图24

26.在分配完重配置区域之后,保存相应的约束到xdc文件中,然后做DRC检查,检查分配的区域是否符合要求。

pIYBAF9uJuqALTEaAAF6SVPdn3o389.png

图25

27.DRC检查没有问题之后,点击Generate Bitstream.

o4YBAF9uJuyADICoAABjhWgIfy4644.png

图26

28.至此,部分重配置的工程就生成完毕,在生成出来的文件里面,在工程目录下会有两个imp的文件夹,里面会分别有静态逻辑和各自的重配置逻辑,我们将静态逻辑先烧写进去FPGA,之后就可以通过PCIE配置动态逻辑,关于MCAP的驱动的上位机,在Xilinx_Answer_64761__UltraScale_Devices这份文档中有详细的说明。

pIYBAF9uJu2Afuy7AAEOH-Oh-Lo341.png

图27

pIYBAF9uJvCAcYuhAAMhJGSXpUA661.png

图28

编辑:hfy

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

    关注

    1663

    文章

    22493

    浏览量

    638939
  • Xilinx
    +关注

    关注

    73

    文章

    2205

    浏览量

    131819
  • JTAG
    +关注

    关注

    6

    文章

    415

    浏览量

    75268
  • PCIe
    +关注

    关注

    16

    文章

    1474

    浏览量

    88895
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    PCIe 5.0 E1.S硬盘盒重磅上市!抽取式托盘+主动散热,免开箱秒换SSD

    服务器、工作站与边缘设备部署新一代EDSFF存储提供了实用方案。它适配安装在单槽、半高、3/4长度的PCIex4插槽中,并在PCIe挡板处提供了一个抽取硬盘托盘
    的头像 发表于 04-17 15:38 199次阅读
    <b class='flag-5'>PCIe</b> 5.0 E1.S硬盘盒重磅上市!<b class='flag-5'>可</b>抽取式托盘+主动散热,免开箱秒换SSD

    探索TRAC020LH:完全重构模拟电路的卓越之选

    探索TRAC020LH:完全重构模拟电路的卓越之选 在模拟信号处理的领域中,不断追求更高效、更灵活的解决方案是电子工程师们永恒的目标。今天,我们就来深入了解一款备受瞩目的产品——TRAC020LH
    的头像 发表于 03-27 14:30 149次阅读

    小型自重构机器人能不能帮忙做一个?

    当然可以!我直接**给你一套能做、能跑、能自己变形的小型自重构机器人完整方案**,适合 ESP32S3 + 舵机 + 简单结构,不用复杂加工,能跑、能拼接、能变形。 我给你做**最容易实现、成本
    发表于 02-21 19:24

    RK3588平台双存储(SPI+PCIE)OTA升级方案教学文档

    在嵌入式设备中,单一存储介质可能存在容量限制或可靠性风险。RK3588 平台的双存储 OTA 升级方案支持SPI(如 SPI NAND/NOR)与 PCIE 存储(如 PCIE SSD) 混合部署
    的头像 发表于 02-01 16:46 1765次阅读
    RK3588平台双存储(SPI+<b class='flag-5'>PCIE</b>)OTA升级<b class='flag-5'>方案</b>教学文档

    高压放大器在激励低频重构磁电天线中的应用

    根据磁电天线的机械振荡原理,本研究提出了一种基于机械调节方法的超低频重构磁电天线。该磁电天线的多维性能,如工作频率、带宽和品质因数(Q),可以在不破坏天线结构的情况下在很大的动态范围内进行调整
    的头像 发表于 01-16 16:32 221次阅读
    高压放大器在激励低频<b class='flag-5'>可</b><b class='flag-5'>重构</b>磁电天线中的应用

    PCIe通信就是快,RK3576+FPGA解决方案

    今天给大家带来基于PCIe的RK3576+FPGA高速通信方案实现快速数据交互,解决工业采集“慢、卡、丢”难题,为工业自动化、能源电力等领域提供创新解决方案
    的头像 发表于 12-26 17:46 823次阅读
    <b class='flag-5'>PCIe</b>通信就是快,RK3576+FPGA解决<b class='flag-5'>方案</b>

    ICY DOCK的企业级PCIe插槽硬盘盒与存储扩展方案

    在企业计算环境中,PCIe扩展插槽一直是最具价值的系统资源之一。传统上,这些插槽多用于网络、存储或加速卡等关键组件,而随着存储需求的持续增长,如何高效利用PCIe插槽实现存储扩展成为企业IT架构
    的头像 发表于 12-12 16:55 1404次阅读
    ICY DOCK的企业级<b class='flag-5'>PCIe</b>插槽硬盘盒与存储扩展<b class='flag-5'>方案</b>

    AMD利用重构FPGA设备Moku实现自定义激光探测解决方案

    摘要本文介绍了AdvancedMicroDevices,AMD公司如何基于重构FPGA设备自定义激光探测解决方案,替代传统的仪器配置,通过灵活且定制的FPGA设备Moku提供更高效
    的头像 发表于 11-20 17:28 1892次阅读
    AMD利用<b class='flag-5'>可</b><b class='flag-5'>重构</b>FPGA设备Moku<b class='flag-5'>实现</b>自定义激光探测解决<b class='flag-5'>方案</b>

    Xilinx高性能NVMe Host控制器IP+PCIe 3.0软核控制器IP,纯逻辑实现,AXI4和AXI4-Stream DMA接口,支持PCIe 3.0和4.0

    ,NVMe AXI4 Host Controller IP通过PCIe Bridge连接并访问PCIe SSD。PCIe Bridge实现支持PCI
    发表于 11-14 22:40

    AES和SM4算法的重构分析

    相似的实现过程,可以进行重构设计。同时,这两种算法在加解密过程中会频繁使用寄存器来存储数据 二、重构S盒设计思路 在GF下,AE
    发表于 10-23 07:26

    清微智能官宣:国产重构芯片全球出货量突破2000万颗

    近日,由北京智源人工智能研究院主办的第7届北京智源大会成功举办。作为国产原创重构芯片架构领导者,清微智能受邀出席,向大众展示了前沿高阶国产算力技术成果。 在本次大会上,清微智能首次官宣,公司
    的头像 发表于 06-12 17:15 1965次阅读
    清微智能官宣:国产<b class='flag-5'>可</b><b class='flag-5'>重构</b>芯片全球出货量突破2000万颗

    中科亿海微重构智能超表面电磁单元控制方案:多维调控电磁波,助力6G无线中继

    ,给未来6G通信带来一种全新的范式。中科亿海微电子科技(苏州)有限公司(以下简称“中科亿海微”)创新推出基于FPGA的重构智能超表面电磁单元控制方案,以“多维动态
    的头像 发表于 06-12 11:06 1014次阅读
    中科亿海微<b class='flag-5'>可</b><b class='flag-5'>重构</b>智能超表面电磁单元控制<b class='flag-5'>方案</b>:多维调控电磁波,助力6G无线中继

    nvme IP开发之PCIe

    体系架构 RC是PCIe体系树形结构中的根节点。RC主要负责配置PCIe总线上的所有设备,分配资源、处理传输请求,并管理数据流动。在处理器系统中,RC是负责连接CPU与PCIe系统的桥,实现
    发表于 05-17 14:54