一个SDSoC设计开发流程需要哪些步骤呢?

在上SDSoC系列文章的上一篇中,我们已经介绍了如何在SDSoC中构建硬件和软件平台,并使用SDSPFM工具生成客户应用开发平台(参见《SDSoC开发起步:构建硬件和软件平台》)。如果你已经完成了上述工作,恭喜你——现在你可以正式“起步”开始基于SDSoC在Zynq SoC上开发自己的应用了!

一个典型的SDSoC设计开发流程,包括以下几个步骤:

用户定义开发应用所需的目标平台。

用户基于C/C++设计和验证算法。

用户根据系统特征描述确定性能瓶颈,然后进行软硬件分区。

SDSoC将自动执行那些通过PL(可编程逻辑)加速的功能,其他功能保留在PS(处理器系统)中。

SDSoC也将自动生成软/硬件之间的连接和DataMover逻辑以连接PL和PS中的功能。

如果最终的结果未达到设计要求,开发者可以重新进行软硬件功能分区,探索最优的系统架构。

 一个SDSoC设计开发流程需要哪些步骤呢?_设计制作_制造/封装

图1,SDSoC典型开发流程(图片来源:赛灵思)

没错,使用SDSoC进行应用开发说起来就是这么简单的几步。我们这篇文章的内容完全可以在这里划上句号。

不过,我们还是希望将现在“简单”的设计流程,和传统上可编程逻辑“不简单”的设计流程进行一个对比,让大家深刻认识到SDSoC到底帮你做了些什么?

所谓“没有对比就没有伤害”,传统的Zynq SoC开发流程是复杂成这个样子的——首先由系统架构工程师对软硬件进行分区,即确定哪些功能放入PL(可编程逻辑)中进行硬件加速,哪些功能在PS(处理器系统)中用软件实现;

接下来,硬件工程师基于Vivado生成要在PL中加速的IP并搭建硬件平台,还要完成软/硬件之间的连接,配置PS与PL之间的接口工作等;然后将硬件平台的数据导入SDK,由软件工程师完成配套的的驱动和应用程序的开发。可见,传统的设计流程,需要很多团队和资源的介入,不简单。

而如果完成了上述设计工作之后,发现系统架构还需要优化,这就悲催了——设计不得不重新调整软硬件分区,上述整个开发流程又要重新进行一遍,而且很多情况下需要多次迭代才能找到那个令人满意的系统架构和方案。由此耗费的时间和资源,是巨大的,甚至是不可控的。

 一个SDSoC设计开发流程需要哪些步骤呢?_设计制作_制造/封装

图2,传统的FPGA SoC应用开发流程(图片来源:赛灵思)

而使用SDSoC之后,很多工作是由工具自动完成的:省去了诸如软件驱动和硬件连接等繁复的手动工作,同时使用C/C++终端应用可以像函数调用一样输入调用用户算法IP;只需要单次点击,就可以完成分区设置以确定需要在可编程逻辑中运行的功能。

 一个SDSoC设计开发流程需要哪些步骤呢?_设计制作_制造/封装

图3,使用SDSoC简化后的FPGA SoC应用开发流程(图片来源:赛灵思)

做一个不是十分准确的比喻:SDSoC与传统工具和开发流程的差别,就像是自动挡与手动挡汽车的不同,它让复杂的工作对用户变得“透明”,让用户实际的“操作”变得更简单,而用户由此被解放出来的精力,则可以用到思考“要去哪儿、如何走”等更高级的问题,而不是和“油离配合”较劲儿。

类比到FPGA SoC的应用开发中,用户最关注的部分往往是算法的最终实现和算法模块的优化——包括IP或是软件功能块——SDSoC的设计理念正是让用户能够更加专注于这些核心问题,其他问题SDSoC帮你搞掂。从这个意义上看,SDSoC在“简单”的背后确实不简单。

60
180
0
85

相关资讯

  1. 1、20万搭配师齐聚《悠悠恋物语》专属套装全服送3924
  2. 2、无兄弟不三国揭秘《超神名将传》军团玩法4848
  3. 3、《恋舞OL》警报发现一超萌不明飞行物坐骑1297
  4. 4、《飞刀无双》iOS大版本更新新英雄新江湖712
  5. 5、《契约勇士》天空之塔的登顶之路5056
  6. 6、《烈焰龙城》沙城战场火爆团队配合有高招639
  7. 7、远古凶兽来袭《新大主宰》全新红卡不死鸟兽尊降世1868
  8. 8、《恋舞OL》登上舞台情侣套装来袭演绎童话之恋4977
  9. 9、《麻辣英雄》新版本问鼎中原上线交互玩法火爆来袭1631
  10. 10、《梦想仙侠》iOS上线炎炎夏日必备良品2083
全部评论(0)
我也有话说
0
收藏
点赞
顶部