91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

該如何提高電路的工作頻率

FPGA設(shè)計論壇 ? 來源:FPGA設(shè)計論壇 ? 作者:FPGA設(shè)計論壇 ? 2022-03-25 09:41 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

對于設(shè)計者來說,當然希望我們設(shè)計的電路的工作頻率(在這里如無特別說明,工作頻率指FPGA片內(nèi)的工作頻率)盡量高。我們也經(jīng)常聽說用資源換速度,用流水的方式可以提高工作頻率,這確實是一個很重要的方法,今天我想進一步去分析該如何提高電路的工作頻率。

我們先來分析下是什么影響了電路的工作頻率。我們電路的工作頻率主要與寄存器到寄存器之間的信號傳播時延及clock skew有關(guān)。在FPGA內(nèi)部如果時鐘走長線的話,clock skew很小,基本上可以忽略, 在這里為了簡單起見,我們只考慮信號的傳播時延的因素。信號的傳播時延包括寄存器的開關(guān)時延、走線時延、經(jīng)過組合邏輯的時延(這樣劃分或許不是很準確,不過對分析問題來說應(yīng)該是沒有可以的),要提高電路的工作頻率,我們就要在這三個時延中做文章,使其盡可能的小。

我們先來看開關(guān)時延,這個時延是由器件物理特性決定的,我們沒有辦法去改變,所以我們只能通過改變走線方式和減少組合邏輯的方法來提高工作頻率。

1.通過改變走線的方式減少時延。以altera的器件為例,我們在quartus里面的timing closure floorplan可以看到有很多條條塊塊,我們可以將條條塊塊按行和按列分,每一個條塊代表1個LAB,每個LAB里有8個或者是10個LE。它們的走線時延的關(guān)系如下:同一個LAB中(最快) < 同列或者同行 < 不同行且不同列。

我們通過給綜合器加適當?shù)募s束(不可貪心,一般以加5%裕量較為合適,比如電路工作在100Mhz,則加約束加到105Mhz就可以了,貪心效果反而不好,且極大增加綜合時間)可以將相關(guān)的邏輯在布線時盡量布的靠近一點,從而減少走線的時延。(注:約束的實現(xiàn)不完全是通過改進布局布線方式去提高工作頻率,還有其它的改進措施)

2.通過減少組合邏輯的減少時延。上面我們講了可以通過加約束來提高工作頻率,但是我們在做設(shè)計之初可萬萬不可將提高工作頻率的美好愿望寄托在加約束上,我們要通過合理的設(shè)計去避免出現(xiàn)大的組合邏輯,從而提高電路的工作頻率,這才能增強設(shè)計的可移植性,才可以使得我們的設(shè)計在移植到另一同等速度級別的芯片時還能使用。

我們知道,目前大部分FPGA都基于4輸入LUT的,如果一個輸出對應(yīng)的判斷條件大于四輸入的話就要由多個LUT級聯(lián)才能完成,這樣就引入一級組合邏輯時延,我們要減少組合邏輯,無非就是要輸入條件盡可能的少,這樣就可以級聯(lián)的LUT更少,從而減少了組合邏輯引起的時延。

我們平時聽說的流水就是一種通過切割大的組合邏輯(在其中插入一級或多級D觸發(fā)器,從而使寄存器與寄存器之間的組合邏輯減少)來提高工作頻率的方法。比如一個32位的計數(shù)器,該計數(shù)器的進位鏈很長,必然會降低工作頻率,我們可以將其分割成4位和8位的計數(shù),每當4位的計數(shù)器計到15后觸發(fā)一次8位的計數(shù)器,這樣就實現(xiàn)了計數(shù)器的切割,也提高了工作頻率。

在狀態(tài)機中,一般也要將大的計數(shù)器移到狀態(tài)機外,因為計數(shù)器這東西一般是經(jīng)常是大于4輸入的,如果再和其它條件一起做為狀態(tài)的跳變判據(jù)的話,必然會增加LUT的級聯(lián),從而增大組合邏輯。以一個6輸入的計數(shù)器為例,我們原希望當計數(shù)器計到111100后狀態(tài)跳變,現(xiàn)在我們將計數(shù)器放到狀態(tài)機外,當計數(shù)器計到111011后產(chǎn)生個enable信號去觸發(fā)狀態(tài)跳變,這樣就將組合邏輯減少了。

上面說的都是可以通過流水的方式切割組合邏輯的情況,但是有些情況下我們是很難去切割組合邏輯的,在這些情況下我們又該怎么做呢?

狀態(tài)機就是這么一個例子,我們不能通過往狀態(tài)譯碼組合邏輯中加入流水。如果我們的設(shè)計中有一個幾十個狀態(tài)的狀態(tài)機,它的狀態(tài)譯碼邏輯將非常之巨大,毫無疑問,這極有可能是設(shè)計中的關(guān)鍵路徑。那我們該怎么做呢?還是老思路,減少組合邏輯。我們可以對狀態(tài)的輸出進行分析,對它們進行重新分類,并根據(jù)這個重新定義成一組組小狀態(tài)機,通過對輸入進行選擇(case語句)并去觸發(fā)相應(yīng)的小狀態(tài)機,從而實現(xiàn)了將大的狀態(tài)機切割成小的狀態(tài)機。在ATA6的規(guī)范中(硬盤的標準),輸入的命令大概有20十種,每一個命令又對應(yīng)很多種狀態(tài),如果用一個大的狀態(tài)機(狀態(tài)套狀態(tài))去做那是不可想象的,我們可以通過case語句去對命令進行譯碼,并觸發(fā)相應(yīng)的狀態(tài)機,這樣做下來這一個模塊的頻率就可以跑得比較高了。

總結(jié):提高工作頻率的本質(zhì)就是要減少寄存器到寄存器的時延,最有效的方法就是避免出現(xiàn)大的組合邏輯,也就是要盡量去滿足四輸入的條件,減少LUT級聯(lián)的數(shù)量。我們可以通過加約束、流水、切割狀態(tài)的方法提高工作頻率。

原文標題:如何提高FPGA的運行速度

文章出處:【微信公眾號:FPGA設(shè)計論壇】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • FPGA
    +關(guān)注

    關(guān)注

    1660

    文章

    22412

    瀏覽量

    636412
  • 電路
    +關(guān)注

    關(guān)注

    173

    文章

    6076

    瀏覽量

    178418
  • 頻率
    +關(guān)注

    關(guān)注

    4

    文章

    1585

    瀏覽量

    62077

原文標題:如何提高FPGA的運行速度

文章出處:【微信號:gh_9d70b445f494,微信公眾號:FPGA設(shè)計論壇】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    使用FPGA搭建的電路,其工作頻率如何設(shè)置

    如題,使用FPGA搭建的電路,其工作頻率如何設(shè)置。是受制于晶振嗎?
    發(fā)表于 05-12 21:15

    設(shè)計一個儀表放大電路,其中的性能如何提高

    現(xiàn)在需要設(shè)計一個儀表放大電路,其中的性能如何提高?如:溫漂、壓擺率、失調(diào)電壓、帶寬
    發(fā)表于 09-11 06:06

    求解釋無線發(fā)射電路工作原理

    本帖最后由 木偶托車 于 2016-4-21 18:04 編輯 1、求解釋無線發(fā)射電路工作原理2、如何改變輸出波形的頻率發(fā)射電路發(fā)射
    發(fā)表于 04-21 17:56

    電路工作原理?

    電路工作原理,器件參數(shù)如何調(diào)到最好?
    發(fā)表于 04-25 09:31

    求教電路工作原理?

    求教電路工作原理?
    發(fā)表于 06-18 15:17

    如何提高FPGA的運行速度(轉(zhuǎn))

    ,今天我想進一步去分析如何提高電路工作頻率。我們先來分析下是什么影響了電路
    發(fā)表于 08-08 11:16

    labview通過myrio采樣 采樣頻率過低 如何提高

    通過myrio采集聲音,labview中通過調(diào)節(jié)時間循環(huán)來改變聲音采樣率,再通過udp通訊將數(shù)據(jù)發(fā)出,但是我發(fā)現(xiàn)因為存在udp通訊,采樣頻率之后1-2K,請問怎么改才能提高采樣頻率,
    發(fā)表于 05-10 16:35

    工作接地按工作頻率而采用的幾種接地方式

    方式:1 單點接地工作頻率低(0.83L (1)式中:L——地線的長度,m;S——地線的截面,mm2。2 多點接地工作頻率高(>30MHz)的采用多點接地式(即在
    發(fā)表于 05-29 06:26

    請教如何提高rkvdec的工作頻率

    問題描述及復(fù)現(xiàn)步驟:各位大神: 有哪位知道如何提供rkvdec的工作頻率嗎?目前在開發(fā)demo中遇到同時解 8 路 1080p@25 幀的rtsp流 幀率不足的問題,目前只能維持在17幀左右。
    發(fā)表于 02-13 10:56

    提高變?nèi)荻O管調(diào)頻電路頻率穩(wěn)定度的溫度補償方法

    提高變?nèi)荻O管調(diào)頻電路頻率穩(wěn)定度的溫度補償方法 在變?nèi)荻O管調(diào)頻電路中,載頻頻率的不穩(wěn)定性主要由溫度變化、電源電壓變化、負載阻抗變
    發(fā)表于 10-20 15:19 ?1848次閱讀
    <b class='flag-5'>提高</b>變?nèi)荻O管調(diào)頻<b class='flag-5'>電路</b><b class='flag-5'>頻率</b>穩(wěn)定度的溫度補償方法

    工作頻率可變的信號發(fā)生器電路

    本內(nèi)容提供了工作頻率可變的信號發(fā)生器電路,歡迎大家參考學(xué)習(xí)
    發(fā)表于 06-22 11:25 ?3032次閱讀
    <b class='flag-5'>工作</b><b class='flag-5'>頻率</b>可變的信號發(fā)生器<b class='flag-5'>電路</b>

    頻率解調(diào)器設(shè)計電路

    電子發(fā)燒友為您提供了靈敏的頻率解調(diào)電路。電路采用鎖相集成電路LM565構(gòu)成,能在很寬的頻率范圍
    發(fā)表于 07-12 10:09 ?1868次閱讀
    <b class='flag-5'>頻率</b>解調(diào)器設(shè)計<b class='flag-5'>電路</b>

    FPGA片內(nèi)的工作頻率如何提高?

    ,今天我想進一步去分析如何提高電路工作頻率。 我們先來分析下是什么影響了電路
    的頭像 發(fā)表于 10-30 12:31 ?1172次閱讀

    FPGA片內(nèi)的工作頻率應(yīng)該如何提高

    ,今天我想進一步去分析如何提高電路工作頻率。我們先來分析下是什么影響了電路
    發(fā)表于 12-15 13:05 ?6次下載

    如何提高FPGA的工作頻率

    頻率,這確實是一個很重要的方法,今天我想進一步去分析如何提高電路工作頻率。 我們先來分析下是
    的頭像 發(fā)表于 11-16 12:10 ?1732次閱讀