<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > FPGA實(shí)戰(zhàn)開發(fā)技巧(6)

          FPGA實(shí)戰(zhàn)開發(fā)技巧(6)

          作者: 時(shí)間:2017-10-13 來源:網(wǎng)絡(luò) 收藏

          5.3.3.2 提高的手段

          設(shè)計(jì)最重要的指標(biāo)之一。造成差的根本原因有很多,但其直接原因可分為三類:布局較差、邏輯級數(shù)過多以及信號扇出過高。下面通過時(shí)序分析實(shí)例來定位原因并給出相應(yīng)的解決方案。

          本文引用地址:http://www.ex-cimer.com/article/201710/365613.htm

          1.布局太差及解決方案

          圖5-13 所示時(shí)序報(bào)告,其中附加的周圍約束為3ns,實(shí)際周期為3.027ns,邏輯時(shí)間只有0.869ns,而布線延遲竟達(dá)到2.203ns,很明顯失敗的原因就是布局太差。

          圖5-13 布局太差的時(shí)序報(bào)告示意圖

          相應(yīng)的解決方案有:

          1) 在ISE 布局工具中調(diào)整布局的努力程度(effort level) ;
          2) 利用布局布線工具的特別努力程度(extra effort) 或MPPR 選項(xiàng);
          3) 如果用戶熟悉區(qū)域約束,則利用Floorplanner 相對區(qū)域約束(RLOC),重新對設(shè)計(jì)進(jìn)行布局規(guī)劃。

          2.邏輯級數(shù)過多及解決方案

          設(shè)計(jì)中,邏輯級數(shù)越高,意味著資源的利用率就越高,但對設(shè)計(jì)工作頻率的影響也越大。在圖5-5所示的例子中,附加的周圍約束為3ns,實(shí)際周期為3.205ns,邏輯時(shí)間為1.307ns,已經(jīng)對設(shè)計(jì)的實(shí)際性能造成了一定的影響。對于這種情況,ISE 實(shí)現(xiàn)工具是沒有任何改善的,必須通過修改代碼來提高性能,相應(yīng)的解決方案有:

          1) 使用流水線技術(shù),在組合邏輯中插入寄存器,簡化原有的邏輯結(jié)構(gòu);
          2) 檢查該路徑是否是多周期路徑,如果是,添加相應(yīng)的多周期約束;
          3) 具備良好的編碼習(xí)慣,不要嵌套if 語句或if、case 語句,并且盡量用case 語句代替if 語句。

          圖5-14 邏輯級數(shù)太多的時(shí)序報(bào)告示意圖

          3.信號扇出過高及解決方案

          高扇出會造成信號傳輸路徑過長,從而降低時(shí)序性能。如圖5-15 所示,附加的周期約束為3ns,而實(shí)際周期為3.927ns,其中網(wǎng)線的扇出已經(jīng)高達(dá)187,從而導(dǎo)致布線時(shí)延達(dá)到3.003ns,占實(shí)際時(shí)延的77.64%。這種情況是任何設(shè)計(jì)所不能容忍的。

          圖5-15 扇出太高的時(shí)序報(bào)告示意圖

          相應(yīng)的解決方案有:

          1) 通過邏輯復(fù)制的方法來降低信號的高扇出,可在HDL 代碼中手動(dòng)復(fù)制或通過在綜合工具中設(shè)置達(dá)到目的;
          2) 可利用區(qū)域約束,將相關(guān)邏輯放置在一起,當(dāng)然本方法僅限于高級用戶。



          關(guān)鍵詞: FPGA 時(shí)序性能

          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();