找回密码
 注册
关于网站域名变更的通知
查看: 465|回复: 1
打印 上一主题 下一主题

关于一些提高fpga运行速度的提示

[复制链接]
  • TA的每日心情
    开心
    2019-11-19 15:19
  • 签到天数: 1 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2019-6-28 13:47 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

    EDA365欢迎您登录!

    您需要 登录 才可以下载或查看,没有帐号?注册

    x
    关于一些提高FPGA运行速度的提示

    - W" f4 X9 b/ \; b8 x/ M9 X/ p8 G( O  E: |3 x: O

    ) G0 `& n- S. F. v3 P3 J/ a

    * i( n- v( s6 Q* ]# H% z  K1. 修改你的系统结构设计,或者VERILOG代码: 这个是最好的方法,另外一个是加TIMING CONSTRAINTS,这个我呆会儿说。具体的方法很多,比如切割大的逻辑,用一个大CLK(比如10NS)完成的大逻辑切割成两个小CLK(6NS)完成的小逻辑,这样虽然延时增加了,但是系统的频率上去了,你的设计就可以突破这个BOTTLE NECK.那什么是大的逻辑什么是小的逻辑,你可以看静态时序报告,这玩艺你一定要懂,不然你做FPGA就是在玩,即使你的设计能跑起来,那你也是玩起来的,而不是做起来的。静态时序报告会提示你那个PATH是延迟最大的,这个延迟就是你设计中制约你频率的PATH,这个延时有两个东西带来,逻辑延迟和布线延迟,逻辑延迟大的话,就切割逻辑为小的逻辑,现在FPGA基本上是一个4输入SRAM,你的逻辑输入就被当作地址,而逻辑结果早就在FPGA配置后放在SRAM里面,这样FPGA运行的时候,根据不同的逻辑输入,从SRAM中取得逻辑结果输出,比如你的逻辑是Fout = f(x,y,z,t),那么x,y,z,t就是当作了一个sram的地址,各种结果就放在sram的16个内存中,根据不同的x,y,z,t来取出结果放在Fout上输出,如果你的逻辑比较复杂,比如要5个输入信号(超过了4个)要在一个clk中完成,那你的逻辑一个sram一定完成不了,需要两个sram,好,这就是一个大逻辑,你要切割它,所谓切割就是搞一个临时中间变量,比如F= X + Y + Z,你可以分为两步走:第一个CLK: TEMP = X + Y;第二个CLK:  F  = TEMP + Z。简单的判断你可以通过综合结果也可以看到,比如在SYNPLIFYPRO里的TECKNOLOGUY OR RTL VIEWER看你的逻辑是不是在一个SRAM里,如果不在就是大逻辑了。另外一个就是布线延迟带来的频率BOTTLE NECK。这就需要用布局布线的TIME CONSTRAINTS来辅助你了。
    / k$ V8 V( z: T) u8 r$ I, A, V
    $ T6 e$ m; \0 ?( c: @+ e/ C2 TIME CONSTRAINTS:作IC的和作FPGA的什么区别:?CONSTRAINTS! 做IC你不但要写RTL CODE,还要加面积CONSTRAINTS,时序CONSTRAINTS,功耗CONSTRAINTS。那你现在就可以明白了CONSTRAINTS有多重要,CONSTRAINTS得工具要看FPGA厂商的工具了,比如ISE QUANTUS。同时在写RTL代码的时候也要加CONSTRAINTS,因为它直接决定你的网表的结构,如果你的RTL的约束写的不好,比如一个状态机有ONEHOT 或者 GRAY CODE风格,你如果写的是ONEHOT风格,但是在CONSTRAINTS却让综合期综合为GRAY CODE风格(现在的综合器很智能,可以把你写的风格代码综合为你设定的CONSTRAINTS其他风格),那你的网表就不一样了,后边的布局布线工具再努力也没有用。! f6 P' z- x- j
    0 d: z7 N, ?' Q7 S3 y
    要加CONSTRAINTS,就要看FPGA厂商的CONSTRAINTS文件格式,比如UCF(ISE),QSF(ALTERA)。具体不谈了,自己好好学习,这个实在太多,比如你看一个逻辑的输入源和输出目的地太远,带来了很大布线延迟,那就把加CONSTRAINTS把他们尽量拉近,但是距离近不一定他们布线就近了,FPGA可能会在两个很近的单元之间布很长的线,你还要在CONSTRAINTS里告诉布局布线工具让他们的的布线也很短,不推荐用手工拉线,这样你以后的代码就不能当作IP给被人用了,而是要用CONSTRAINTS,这样你以后写好RTL代码和CONSTRAINTS文件,就能当作IP卖给客户了,不然你就留着自己玩玩算了。CONSTRAINTS很多,不具体说了,最重要的是PERIOD或者Fmax约束,分别对应xilinx和altera,具体自己学习,不多说了,一般的应用用这两个CONSTRAINTS就可以了。0 T5 f6 A$ [' W, N% R

      {/ ^. @( t- w) g- U: O

    该用户从未签到

    2#
    发表于 2019-6-28 17:05 | 只看该作者
    EDA365有你更精彩
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-8-5 03:52 , Processed in 0.109375 second(s), 24 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表