国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

FPGA開發流程:詳述每一環節的物理含義和實現目標

發布時間:2015-3-16 15:54    發布者:designapp
要知道,要把一件事情做好,不管是做哪們技術還是辦什么手續,明白這個事情的流程非常關鍵,它決定了這件事情的順利進行與否。同樣,我們學習FPGA開發數字系統這個技術,先撇開使用這個技術的基礎編程語言的具體語法、使用工具和使用技巧不談,咱先來弄清楚FPGA的開發流程是什么。
FPGA的開發流程是遵循著ASIC的開發流程發展的,發展到目前為止,FPGA的開發流程總體按照圖1進行,有些步驟可能由于其在當前項目中的條件的寬度的允許,可以免去,比如靜態仿真過程,這樣來達到項目時間上的優勢。但是,大部分的流程步驟還是需要我們循規蹈矩的去做,因為這些步驟的輸入是上一個步驟的結果,輸出是下一個步驟的輸入的關系,這樣的步驟就必不可少了。


圖1

有人看到這個流程圖的時候,第一個發自內心的感嘆是“啊,怎么這么麻煩啊,特別是之前從事軟件開發轉過來的。對于他們來講,很少有接觸到一種技術有如此多的環節來實現。但是這并不能說明FPGA開發的具體難度,與軟件開發有輸入、編譯、鏈接、執行步驟對應的就是設計輸入、綜合、布局布線、下載燒寫,FPGA開發只是為了確保這核心實現主干路每一個環節的成功性加了其他的修飾(約束)和驗證而已。下面,我們將以核心主干路為路線,一一介紹每個環節的物理含義和實現目標。
        
5.1設計輸入
5.1.1設計輸入方式
從圖1 FPGA開發流程中的主干線上分離出第一步設計輸入橫向環節,并做了進一步的細節的處理,如圖2,從圖上看到,設計輸入方式有三種形式,有IP核、原理圖、HDL,由此展開設計輸入方式的探討。


圖2

原理圖輸入
原始的數字系統電路的設計可能大家還不可能想象,是用筆紙一個個邏輯門電路甚至晶體管搭建起來的,這樣的方式我們稱作原理圖的輸入方式。那個時候,硬件工程師們會圍繞的坐在一塊,拿著圖紙來討論電路。幸虧那時候的數字電路的還不是很復雜,要是放到今天,稍微大一點的系統,也算得上是浩大工程,稍微有點電路要修改的話,這個時候你要是一個沒耐心或是一個急性子的人可能就就會喪失對這個領域的興趣。話說回來,那個年代出來的老工程師們,電路基礎功夫確實很扎實。
事情總是朝著好的方向發展的,后來出現了大型計算機,工程師們開始將最原始的打孔的編程方式運用到數字電路設計當中,來記錄我們手工繪畫的電路設計,后來存儲設備也開始用上了,從卡片過度到了存儲文本文件了,那個時候網表文件大致是起于那個時候。
需要注意的問題是原理圖和網表文件的關系,原理圖是我們最開始方便我們設計的一個輸入方式,而網表文件是計算機傳遞原理圖信息給下一道流程或是給仿真平臺進行原理圖描述仿真用的。設計輸入方式不一樣,但是對于功能仿真來講,最終進度到仿真核心的應該是同一個文件,那么這個文件就是網表文件了。
有了計算機的輔助,數字電路設計起來可以說進步了一大截,但是如果依然全部是基于邏輯門晶體管的話,還是比較繁瑣。于是后來出現了符號庫,庫里包含一些常用的具有通行的器件,比如D觸發器類的等等,并隨著需求的發展,這些符號庫不斷的在豐富。與在原理圖里利用這些符號庫構建電路對應的是,由原理圖得到的這個網表文件的描述方式也相應的得到擴展,那么這里網表文件里對電路符號的描述就是最開始的原語了。
作為最原始的數字電路ASIC設計輸入的方式,并從ASIC設計流程延續到FPGA的設計流程,有著它與生俱來的優點,就是直觀性、簡潔性,以致目前依然還在使用。但是需要注意的是,這也是相對的,具體討論見下一小節。
HDL輸入
HDL全稱是硬件描述語言Hardware Description Language,這種輸入方式要追溯的話得到20世紀90年代初了。當時的數字電路的規模已足以讓按照當時的輸入方式進行門級抽象設計顧左顧不了右了,一不小心很容易出錯,而且得進行多層次的原理圖切割,最為關鍵的是如何能做到在更抽象的層次上描述數字電路。
于是一些EDA開始提供一種文本形式的,非常嚴謹,不易出錯的HDL輸入方式開始提供了。特別是在1980年的時候,美國軍方發起來甚高速集成電路(Very-High-Speed Integrated Circuit)計劃,就是為了在部隊中裝備中大規模需求的數字電路的設計開發效率,那么這個VHSIC硬件描述語言就是我們現在的VHDL語言,它也是最早成為硬件描述語言的標準的。與之相對的是晚些時間民間發起的Verilog, 后來到1995年的時候,它的第一個版本的IEEE標準才出臺,但是沿用至今。
前面提到HDL語言具有不同層次上的抽象,這些抽象層有開關級、邏輯門級、RTL級、行為級和系統級,如圖3。其中開關級、邏輯門級又叫結構級,直接反映的是結構上的特性,大量的使用原語調用,很類似最開始原理圖轉成門級網表。RTL級又可稱為功能級。


圖3

HDL語言除了前面提到的兩種外,歷史上也出現了其他的HDL語言,有ABEL、AHDL、硬件C語言(System C語言、Handle-C)、System verilog等。其中ABEL和AHDL算是早期的語言,因為相比前面兩種語言來講,或多或少都有些致命的缺陷而在小范圍內使用或者直接淘汰掉了。而因為VHDL和Verilog在仿真方面具有仿真時間長的缺陷,System verilog和硬件C語言產生了,從圖3看,System Verilog是在系統級和行為級上為Verilog做補充,同時硬件C語言產生的原因還有就是有種想把軟件和硬件設計整合到一個平臺下的思想。
IP(Intellectual Property)核
什么是IP核?任何實現一定功能的模塊叫做IP(Intellectual Property)。這里把IP核作為一種輸入方式單獨列出來,主要考慮到完全用IP核確實是可以形成一個項目。它的產生可以說是這樣的一個逆過程。
在隨著數字電路的規模不斷擴大的時候,面對一個超級大的工程,工程師們可能是達到一種共識,將這規模巨大而且復雜的設計經常用到的具有一定通用性的功能給獨立出來,可以用來其他設計。當下一次設計的時候,發現這些組裝好的具有一定功能的模塊確實挺好用的,于是越來越多的這種具有一定功能的模塊被提取出來,甚至工程師之間用來交換,慢慢大家注意到它的知識產權,于是一種叫做IP知識產權的東西出來了,于是集成電路一個全新領域(IP設計)產生了。
IP按照來源的不同可以分為三類,第一種是來自前一個設計的內部創建模塊,第二種是FPGA廠家,第三種就是來自IP廠商;后面兩種是我們關注的,這是我們進行零開發時考慮的現有資源問題,先撇開成本問題,IP方式的開發對項目周期非常有益的,這也是在FPGA應用領域章節陳列相關FPGA廠家IP資源的原因。
FPGA廠家和IP廠商可以在FPGA開發的不同時期提供給我們的IP。我們暫且知道他們分別是未加密的RTL級IP、加密的RTL級IP、未經布局布線的網表級IP、布局布線后的網表級IP。他們的含義在后面陸續介紹FPGA的開發步驟的時候,相信大家能夠恍然大悟。需要說明的是,越是FPGA靠前端步驟的時候提供的IP,他的二次開發性就越好,但是它的性能可能是個反的過程,同時也越貴,畢竟任何一個提供者也不想將自己的源碼程序提供給他者,但是為了不讓客戶走向其他商家,只能提高價賣了,同時加上一些法律上的協議保護。那么越朝FPGA開發步驟的后端,情況就相反了,越是后端,IP核就會進一步做優化,性能就越好,但是一些客戶不要的功能就不好去了。
FPGA廠商提供一般常用的IP核,畢竟為了讓大家用他們家的芯片,但是一些特殊需要的IP核還是需要付費的。當然這里需要說明的是FPGA廠商的IP是很少可以交叉用的,這一點很容易想,對廠家來講不會做這種給競爭者提供服務事情的。IP廠商一般會高價的提供未加密的RTL級源碼,有時FPGA廠商為了擴大芯片市場占有率,會購買第三方的IP做進一步的處理后免費提給該FPGA芯片使用者的。
5.1.2輸入方式使用探討
在上面我們介紹了三種輸入方式,有些地方會講到第四種輸入方式,就是門級網表文件輸入的形式,我們這里并沒有把它歸為一種輸入方式,原因在于,本身這些門級網表文件的產生還是源于介紹的三種輸入方式中的一種或是幾種混合的方式。所以這里沒有把它歸為一類。
好了,在上面三種輸入方式介紹的基礎上,我們來探討一下這令人眼花繚亂的輸入方式,探討的目的就是為了讓我們更好的使用他們。
首先,來總結一下三者的優缺點,其實是兩種,因為IP核不管是哪個層次,或者在原理圖中被以符號的形式被例化,或者在HDL中被模塊例化。所以這里集中探討的是原理圖和HDL的優缺點。原理圖的優點就是結構直觀性,HDL的優點是嚴密性、支持甚寬的抽象描述層次、易于移植、方便仿真調試等等,缺點就是不具備對方的優點。當時出現HDL的時候,人們確實是想著原理圖該退出歷史舞臺了,但是到現在它還依然存在著。存在即是有道理的,存在就得用它,但是又得使用HDL,于是存在一種混合編程的形式。除了頂層模塊用原理圖之外,其他的內部子模塊全部使用HDL來描述,HDL描述的模塊可以通過工具轉換成符號,然后在頂層模塊中引用這些符號,這就完成混合編程。


圖4

在接觸的很多FPGA的初學者很容易被原理圖的輸入方式給迷惑,甚至愛的深沉,加上本身其他輸入方式的繁瑣的輸入的厭惡,更是愛的無法自拔。當開始強制性要求開始時養成多用HDL輸入的習慣的時候,有些甚至有著痛心疾首般的痛苦,但是隨著學習的深入,做的東西越來越大,嘗到HDL輸入方式帶來的甜頭的時候,就會覺得那個苦沒有白吃。
我覺得原理圖輸入方式從現在的一些線索看來,在今后的某一天將會服役終結。首先是找到了原理圖自身帶有優勢的替代品,那就是主流FPGA集成環境中的綜合器和第三方綜合器都具有RTL視圖生成功能,這個視圖完全展示了項目的結構組成,可以上下分層,最大的好處就是可以檢查核實寫的RTL級代碼的綜合后電路情況。還有一條線索是,大家用的仿真軟件Modelsim并沒有提供原理圖輸入的支持,是原理圖的設計必須在集成環境成轉換成RTL級代碼或是綜合成網表形式來做仿真,也是一件繁瑣的事。原理圖的離開只是時間問題。
至于目前HDL選擇哪一種比較好,這個問題放到開始將HDL基礎語法知識的地方進行探討。這里要說明的是,并不是我們這里講Verilog使用就否定其他的HDL語言。各種HDL的爭端從未停止過,現在還是依然存在四種開發人,第一種是使用Verilog/System Verilog的人,第二種是使用VHDL的人,第三種就是使用System C的人,第四種是混合型的人,到底哪種好,也有也許是時間問題吧,時間證明一切。
5.2 綜合
不管你是采用單一的輸入方式,還是采用的是混合編程(這種在很多跨公司合作項目中會碰見,也許A公司用的是VHDL,B公司用的是Verilog,那這個項目中很大可能采用混合型),我們統稱得到設計輸入后,都得把設計輸入得到一個可以和FPGA硬件資源相匹配的一個描述。假設FPGA是基于LUT結構的,那么我們就得到一個基于LUT結構門級網表。在這個過程中,又可以分為如圖兩個步驟。


圖5

需要說明的是在Altera的開發流程中,將編譯、映射過程按照我們敘述的合稱綜合,而在Xilinx開發流程中,由設計輸入得到門級網表的過程叫做綜合,而映射過程歸結到其叫做實現的某一子步驟中。但是整體的流程還是遵循這個順序的,只是叫法一些外表性的不一樣而已。
5.2.1編譯
原理圖、HDL、IP核這些都將通過編譯后生成門級的網表,這里生成門級網表的過程其實是早起ASIC的步驟,直接生成門電路網表。這個時候的網表文件和具體的器件無關,也就是說,生成的門電路網表也是一種平臺移植的媒質。
5.2.2映射
我們通過編譯得到一張門級網表之后,與早先ASIC開發流程中在這個門級網表布線后去做掩膜不同,接下來就得考慮如何與我們選擇的硬件平臺結合起來,畢竟我們使用的硬件平臺是由一個一個的LUT(假設這類FPGA)組成的。那么這個結合的過程就是映射過程。
這個過程其實很復雜,首先需要把形成的網表邏輯門給規劃成一些小的組合,然后再去映射到LUT中,這個過程中規劃按照一定的算法和章程進行。不同的算法和章程就會得到不同的映射,不同的映射就會為后面的過程提供不同的選擇,最終生成性能不一樣的電路了。
我們把講基于SRAM技術的FPGA的二選一多路器拿出來舉個例子,如圖6,可以按照紅色線將二選一多路器完全劈成兩邊,原來的一個表就可以規劃到其他兩個表或表內容中,因為被劈成的兩部分可單獨成表,也可以被規劃到其他電路形成的表里。


圖6

映射的工程比較復雜,運算量也很大,也是為什么FPGA開發過程中,一直存在的一個問題,形成最終的可配置二進制文件的時間非常長,特別是一些大一點的項目,時間消耗比較長的一個點就是映射了,至于具體的映射算法就超出了書的范圍了。再強調的是,映射是和器件有關的,即使是同一個系列,不同型號的FPGA內部就夠也是有區別的,好比從外觀看都是一個單元樓內的單元房,但是每個單元房內裝修、家具擺設等都是不一樣的。
        
5.3 布局布線
5.3.1 布局
講到這一塊,正好有這么一個例子來講解這個概念。近來報道朝鮮希望在俄羅斯遠東地區租用數十萬公頃的土地用來培育農產品。咱先撇開今后的購買的成功與否,假設成功了,并且有了這個詳細的希望培育的農作物的品種及數量,有各式各樣的蔬菜、主糧、禽類畜養場、果樹等等。我們前面做的那些流程得到的LUT門級網表就好比這樣的清單。
得到這樣的清單之后,我們再假設在這十萬公頃的土地上,陽光、水資源、溫差都有一定的分布。大家知道農作物的的成長和高量產或者與陽關有關,或者與水資源有關,或者與溫差有關,并且禽類的畜養材料與農作物的副產有關。所以接下來要做的事情就是根據現有的自然條件和農產品的所需環境特點合理布局,哪些地適合做什么。
緊接著我們回到FPGA開發中來,我們通過前面的步驟得到的清單就是LUT門級網表。網表里提供的僅僅是從邏輯關系上一些LUT結構的連接。我們需要將這些LUT結構配置到FPGA具體的哪個位置。需要說明的是,FPGA里任何硬件結構都是按照橫縱坐標進行標定的,圖中選中的是一個SLICE,SLICE里面存放著表和其他結構,它的位置在X50Y112上。不同的資源的坐標不一樣,但是坐標的零點是公用的。


圖7

在FPGA里布局需要考慮的問題是,如何將這些已有的邏輯上連接的LUT及其它元素合理的放到現有的FPGA里,達到功能要求的時候保證質量。具體點就比如,乘法器這樣的電路適合放在RAM附近,當然,硬件乘法器的硬件布局一般也是在存儲器附近,有利于縮短乘法的延時時間,什么樣的電路需要配置高速等等。
十萬公頃的地布局規劃好了,農產品就會有很好的豐收,同樣FPGA開發布局布好了,由FPGA搭建起來的電路就會更加穩定和擴展性。
5.3.2 布線
上小節中,我們把十萬公頃的地給安排好了,哪些地該種什么。具體實施之前還有一些是必須做的,比如農作物的澆灌,沒有一個很好的灌溉系統是一個問題;再比如豐收了得采摘吧,這個時候,能夠讓大卡車到達每一塊農地的公路樞紐也是需要解決的問題。將每一塊或者相關的田地連接的灌水系統和公路的建設,就好比我們這個布線的過程。
我們在FPGA內通過布局,知道那些LUT具體分布到哪個SLICE,但是一方面如何讓這些SLICE連接起來,二方面如何讓輸入的信號到達相應的開始處理點和如何讓輸出到達輸出IO上,并且連接的電路整體性能好,這就是布線這個環節需要完成的內容。要達到布線最優話,當然這里面設計到布線算法和很多細節問題,比如涉及到布線資源、PLL資源分布。但是這些對我們理解布線這個概念沒有很多益處,暫且不深入,本質上就是一個線路求最優的問題。
        
5.4 約束
約束,在圖1上看到,在綜合和布局布線這兩個流程環節里都出現了,我們暫且規定其為約束一和約束二,或者說綜合約束和布局布線約束,布局布線約束又可以分為位置約束、時序約束。約束,就是對這些環節操作定制規則。一般開發環境會對這些約束有個默認,這些默認的設置對大部分情況下還是適用的,但是通常布局布線約束中的I/O約束是我們每一個工程都必須給定的。同時開發工具開放其他約束接口,允許我們設置這些規則,具體的有哪些約束怎么去做在后面介紹工具使用的時候進行討論,這里先明白這些約束的基本概念。
綜合約束
相信大家已經下意識的將綜合約束和綜合過程掛在一起了,沒錯,綜合約束確實是在綜合過程中做的,用來指導綜合過程,包括編譯和映射。我們已經知道綜合過程是將RTL級電路描述轉換到FPGA上的硬件單元(LUT)中,形成以FPGA存在的硬件單元構成的電路。
我們還是拿前面有過的例子來說明,不同的約束將導致生成性能不同的電路。綜合這么一個完成式***能的電路,沒有加資源共享得到的電路如圖8左邊所示的電路,而加了資源共享的約束后,得到的電路結構如圖8右邊的電路。


圖8

通過之前的分析,得到左邊的電路結構資源消耗多但是速度快,而右邊的結構消耗資源少,但是速度慢,乘法器需要分時復用。
當然這只是一個例子,但是足以說明,不同的綜合指導原則也就是綜合約束,將會產生不同的電路。當得到的電路性能不能滿足需求的時候,適當考慮綜合約束,來達到一個速度和面積的轉換的效果,實現性能的提升。電路實現的速度和消耗的面積是貫穿在FPGA開發過程中兩個 矛盾的問題,綜合約束是其中一種小范圍內實現速度和面見平衡點移動的方式。
位置約束
沒錯,你又想對了,位置約束和我們布局有關系,它就是指布局的策略。根據所選擇的FPGA平臺現有硬件資源分布來決定我們布局。
其中最典型的位置約束就是I/O約束。一個典型的系統是既有輸入也有輸出的,而不管是輸入還是輸出,都是從I/O上為端點的。輸入從哪個端點進來,輸出從哪個端點出去,輸入是需要支持什么樣的電氣特性的端點,輸出又是需要支持什么樣的電氣特定的端點。這些都是I/O約束做的事情。任何一個工程,都必須有這么一個約束。
還有一種典型的位置約束是在增量編譯里涉及的物理界定。增量編譯的出現就是因為在FPGA開發過程中綜合和布局布線的長耗時性而提出的。思想就是把FPGA切成很多個小塊的FPGA,然后約定具體哪塊小FPGA放置什么模塊,實現什么樣的功能,從物理上進行界定。當修改工程后,開發平臺就會檢測哪些小FPGA內沒有進行修改,哪些進行了修改,然后將修改過的部分重新進行綜合布局布線步驟。這樣一來,相比原來修改一點,全工程重新經過那些過程來講,時間節省下來了。
時序約束
估計沒有多少懸念了,時序約束很大程度上和布線有關。為什么要做這個約束?
由于一方面信號在芯片內傳遞是需要消耗時間的,另一方面大量存在的寄存器有反應時間,而我們開發的最開始的時候這些時間都是理想化的。但是考慮到真實情況下,如果跑的速度比較高,達到了200M這么個速度,當然這個高速和具體的芯片有關,高性能的芯片本身跑的速度可以達到很高,200M相對來說就不是高速,對一些低性能芯片還可能達不到200M。這個時候,這些時間達到了同樣一個系統時間數量級的時候,很可能影響電路的性能了。某一刻,該來的信號沒有來,默認的話就會采集錯誤信號了。
為了讓這些硬件本身帶來的延時時間更理想化,我們就要對這些決定時間延時的因素優化來減少時間延時。對于寄存器本身的反應時間這個因素我們開發者是無能為力的,我們要做的優化就是布線了。是走直線還是走其他,不僅僅決定于自身這條路徑,還和整個系統布線有關,好比水桶原理,系統性能決定于最差路徑延時。
時序約束做的就是這些事情,但是時序約束并不是指具體去連接每一條線,這個工作就像前面那些流程一樣都是由軟件去實現的,先用軟件自己默認原則布線,然后對其結果分析,不滿足時序要求的,我們再對具體的問題路徑做一些指導約束。時序約束的添加,主要包括周期約束、輸入偏移約束和輸出偏移約束。具體的過程在后面章節介紹工具使用時會有具體動手的指導。
        
5.5 FPGA開發仿真
在經過上面從設計輸入到綜合再到布局布線過程的介紹后,我們來集中探討一下,在這些過程中涉及到的相應的仿真。
仿真,字面上講就是模擬真實狀況。我們FPGA設計里面的仿真,就是模擬真實電路的狀況,查看電路是不是我們需要的電路。如果我們把FPGA開發形成電路當作一個產品的生產過程,那么在FPGA開發流程中含有的三種仿真(RTL級仿真、靜態仿真和時序仿真)就好比產品線中的三道檢測站。如圖9,這三道工序任何一道出了問題,修改設計后都得重新走這三道卡,所以盡量在把問題發現在源頭。


圖9

5.5.1 測試平臺
所謂testbench,即測試平臺,詳細的說就是給待驗證的設計添加激勵,同時觀察輸出響應是否符合設計要求。測試平臺,測試平臺在做功能仿真、靜態仿真和時序仿真的時候都需要用到。剛開始的對于一些初學者,遇到的都是一些簡單的東西,測試平臺相應的也很簡單,用一個文件就可以很清晰的呈現測試結構。對于一些復雜的項目,測試就沒有那么簡單了,由此還專門產生一個行業——測試行業。這個時候我們要用到一個概念就是結構化測試。
一個完整的測試平臺如下圖10所示,它是分結構組成的,其中對設計測試結果的判斷不僅可以通過觀察對比波形得到,而且可以靈活使用腳本命令將有用的輸出信息打印到終端或者產生文本進行觀察,也可以寫一段代碼讓它們自動比較輸出結果。


圖10

測試平臺的設計是多種多樣,可以使用靈活的Verilog的驗證腳本,但是它也是基于硬件語言但是又服務于軟件測試的語言,有時并行有時順序,只有掌握這些關鍵點,才能很好服務測試。需要說明的一點是,不管大家是已經在用Verilog在寫測試平臺還是剛學習寫測試平臺,那么建議大家還是能用到System Verilog中相對Verilog新的語法還是嘗試的用,System Verilog是一種趨勢,它本身就是向下兼容的第三代的Verilog。
5.5.2 RTL級仿真
這里RTL級仿真屬于第一道檢測,有些場合稱作功能仿真,為了突出和后面的靜態仿真的區別,以免在后面介紹靜態仿真的時候大家弄的很頭大,我們還是這樣稱呼。它是對工程在寄存器轉送級進行的描述時進行測試,查看其在RTL級描述的時候實現的功能的正確性。
關于RTL級仿真,如果設計中設計到原理圖輸入的話,在一些仿真工具中是不支持的,比如Modelsim,這個時候要進行功能上的驗證,可以將原理圖轉換成HDL描述,或者直接把整個工程轉換成LUT門級網表后進行后面要講到的靜態仿真完成。
所有邏輯功能的驗證都希望在RTL級做,盡可能的將問題發現在RTL級仿真過程中,減少后面發現問題帶來的反復。
5.5.3 靜態仿真
靜態仿真,有些地方給的外號叫門級仿真,確切的說應該是綜合后的LUT門級網表。是在綜合過程后做的仿真。有些開發平臺下將靜態仿真具體又分為編譯仿真和映射仿真,比如ISE就是這樣做的,但是個人覺得應該很少場合做這個編譯仿真。靜態仿真的目的就是驗證當工程到了用LUT門級網表描述的時候,從功能上檢查驗證工程的正確性。
不管是Altera還是Xilinx的開發平臺,都直接支持靜態仿真,但是由于各自廠家的仿真器專業性不強,我們還是用第三方仿真工具比較多。這時候在第三方工具下的輸入必須是經過綜合工具綜合出來的涵蓋工程所有信息的LUT門級網表文件了。一般專業一點的第三方綜合工具是不具備綜合功能的,至少我們在使用Modelsim的時候,并沒有要求我們添加工程用到的具體的哪一款型號FPGA的信息。這也是靜態仿真的外號門級仿真指的是LUT門級網表仿真的依據。
5.5.4 時序仿真
時序仿真是在布局布線之后做的,在前面介紹時序約束的時候講到,布線延時問題影響到了電路的性能的時候可以做時序約束。那么這個延時問題的獲得就可以通過時序仿真獲得,當然還有一種獲得延時出現超載情況,這個屬于下面小節介紹的靜態時序分析了。
一般情況下,電路進行完布線過程后,會生成一個延時信息文件,我們簡稱SDF(standrad dealy format)文件,Quartus平臺下是以.sdo文件形式存在的。里面含有三種延時信息,分別為最小值、典型值、最大值,存在的形式是最小值:典型值:最大值,一般縮寫min:typ:max。這里也體現了,在FPGA里的延時信息是不能夠精確獲得的,只能是逼近,因為本身同一器件中,不同的區域的邏輯門也很有可能和其他的區域內同種的邏輯門的延時不一樣。我們這里舉一個例子來說明一下這三種值的含義。


圖11

如上圖,這是一個描述一段延時線的延時信息,給的延時信息從in端點到out端點,輸入發生跳變后,分別以最小值、典型值和最大值將信號跳變傳遞到out端點。我們這里只是一段延時線,在延時信息文件里還有一類延時信息,就是一些具有邏輯功能的cell延時,這個時候信號跳變又分為由高變低和有低變高,因為這兩種跳變在這些器件里的三種延時值是不一樣的,得分別探討,具體分別以某一種情況類推。
在做后仿真的時候,只需要在做完靜態仿真后的基礎上添加布線的延時信息后,再分析邏輯功能是否滿足要求。后方針的平臺 使用情況和前面一樣,一般采用第三方仿真工具,典型的是Modlesim,具體操作過程見軟件相關操作章節。
        
5.9開發工具總結
在圍繞圖1把FPGA開發流程講完后,這里對每個環節中設計的相關軟件進行總結,如下表所示。畢竟充分利用各種工具的特點,進行多種EDA工具的協同設計,對FPGA的開發是非常重要的。充分利用了這些EDA工具的優點,能夠提高開發效率和系統性能。



表中列出的每種EDA工具都有自己的特點。一般由FPGA廠商提供的集成開發環境,如Altera Quartus II和Xilinx ISE,在邏輯綜合和設計仿真環節都不是非常優秀,因此一般都會提供第三方EDA工具的接口,讓用戶更方便地利用其他EDA工具。為了提高設計效率,優化設計結果,很多廠家提供了各種專業軟件,用以配合FPGA芯片廠家提供的工具進行更高效的設計。
比較常見的使用方式是:FPGA廠商提供的集成開發環境、專業邏輯仿真軟件、專業邏輯綜合軟件一起使用,進行多種EDA工具的協同設計。比如Quartus II+ModelSim+FPGA Compiler II,ISE+ModelSim+Synplify Pro等等。

來源于: EDNC BLOG 北航蘇陽-Sun的博客




本文地址:http://m.qingdxww.cn/thread-146941-1-1.html     【打印本頁】

本站部分文章為轉載或網友發布,目的在于傳遞和分享信息,并不代表本網贊同其觀點和對其真實性負責;文章版權歸原作者及原出處所有,如涉及作品內容、版權和其它問題,我們將根據著作權人的要求,第一時間更正或刪除。
您需要登錄后才可以發表評論 登錄 | 立即注冊

廠商推薦

  • Microchip視頻專區
  • 使用SAM-IoT Wx v2開發板演示AWS IoT Core應用程序
  • 使用Harmony3加速TCP/IP應用的開發培訓教程
  • 集成高級模擬外設的PIC18F-Q71家族介紹培訓教程
  • 探索PIC16F13145 MCU系列——快速概覽
  • 貿澤電子(Mouser)專區

相關視頻

關于我們  -  服務條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯系我們
電子工程網 © 版權所有   京ICP備16069177號 | 京公網安備11010502021702
快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产三级精品久久三级国专区 | 亚洲男人网| 国产亚洲欧美在线观看的 | 国内外成人免费视频 | 朋友的母亲在线播放 | 欧美成人自拍视频 | 在线观看樱花动漫 | 久青草香蕉精品视频在线 | 亚洲精品蜜桃久久久久久 | 欧美一区二区三区视频 | 一级毛片免费观看视频 | 在线观看网址入口2020国产 | 99热国产在线 | qvod经典视频在线播放 | 亚洲综合精品一二三区在线 | 欧美一进一出抽搐大尺度视频 | 他是谁电视剧免费观看 天堂 | 天天爆操 | 精品欧美成人bd高清在线观看 | 91麻豆精品国产综合久久久 | 华人91视频 | 国产中日韩一区二区三区 | 国产精品视频二区不卡 | 色费女人18毛片a级视频在线 | 亚洲视频一区二区三区四区 | 色视频免费观看高清完整 | 成年人午夜网站 | 免费一级a毛片在线搐放正片 | 日韩综合在线观看 | 国内精品 第一页 | 激情亚洲| 亚洲人成综合网站在线 | 免费视频h| 99ri在线 | 国产在线午夜 | 久久免费观看视频 | 九九热精品免费视频 | 99久久99久久精品免费看子 | 免费亚洲视频在线观看 | 成 人 a v免费视频 | 天堂最新版资源www在线 |