




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、FPGA相關(guān)資料第一章1FPGA和FPGA數(shù)字系統(tǒng)(1)可編程邏輯器件概述可編程邏輯器件 英文全稱為:programmable logic device 即 PLD。PLD是做為一種通用集成電路產(chǎn)生的,他的邏輯功能按照用戶對器件編程來確定。一般的PLD的集成度很高,足以滿足設(shè)計一般數(shù)字系統(tǒng)的需要。這樣就可以由設(shè)計人員自行編程而把一個數(shù)字系統(tǒng)“集成”在一片PLD上,而不必去請芯片制造廠商設(shè)計和制作專用的集成電路芯片了。PLD與一般數(shù)字芯片不同的是:PLD內(nèi)部的數(shù)字電路可以在出廠后才規(guī)劃決定,有些類型的PLD也允許在規(guī)劃決定后再次進(jìn)行變更、改變,而一般數(shù)字芯片在出廠前就已經(jīng)決定其內(nèi)部電路,無法在出
2、廠后再次改變,事實上一般的模擬芯片、混訊芯片也都一樣,都是在出廠后就無法再對其內(nèi)部電路進(jìn)行調(diào)修。邏輯器件可分為兩大類 - 固定邏輯器件和可編程邏輯器件。 一如其名,固定邏輯器件中的電路是永久性的,它們完成一種或一組功能 - 一旦制造完成,就無法改變。 另一方面,可編程邏輯器件(PLD)是能夠為客戶提供范圍廣泛的多種邏輯能力、特性、速度和電壓特性的標(biāo)準(zhǔn)成品部件 - 而且此類器件可在任何時間改變,從而完成許多種不同的功能。對于固定邏輯器件,根據(jù)器件復(fù)雜性的不同,從設(shè)計、原型到最終生產(chǎn)所需要的時間可從數(shù)月至一年多不等。 而且,如果器件工作不合適,或者如果應(yīng)用要求發(fā)生了變化,那么就必須開發(fā)全新的設(shè)計。
3、 設(shè)計和驗證固定邏輯的前期工作需要大量的“非重發(fā)性工程成本”,或NRE。 NRE表示在固定邏輯器件最終從芯片制造廠制造出來以前客戶需要投入的所有成本,這些成本包括工程資源、昂貴的軟件設(shè)計工具、用來制造芯片不同金屬層的昂貴光刻掩模組,以及初始原型器件的生產(chǎn)成本。 這些NRE成本可能從數(shù)十萬美元至數(shù)百萬美元。對于可編程邏輯器件,設(shè)計人員可利用價格低廉的軟件工具快速開發(fā)、仿真和測試其設(shè)計。 然后,可快速將設(shè)計編程到器件中,并立即在實際運行的電路中對設(shè)計進(jìn)行測試。 原型中使用的PLD器件與正式生產(chǎn)最終設(shè)備(如網(wǎng)絡(luò)路由器、ADSL調(diào)制解調(diào)器、DVD播放器、或汽車導(dǎo)航系統(tǒng))時所使用的PLD完全相同。 這樣
4、就沒有了NRE成本,最終的設(shè)計也比采用定制固定邏輯器件時完成得更快。采用PLD的另一個關(guān)鍵優(yōu)點是在設(shè)計階段中客戶可根據(jù)需要修改電路,直到對設(shè)計工作感到滿意為止。 這是因為PLD基于可重寫的存儲器技術(shù)-要改變設(shè)計,只需要簡單地對器件進(jìn)行重新編程。 一旦設(shè)計完成,客戶可立即投入生產(chǎn),只需要利用最終軟件設(shè)計文件簡單地編程所需要數(shù)量的PLD就可以了。常見的PLD產(chǎn)品:可編程只讀存儲器(PROM)、現(xiàn)場可編程邏輯陣列(FPLA)、可編程陣列邏輯(PAL)、復(fù)雜可編程邏輯器件(CPLD)、和現(xiàn)場可編程門陣列(FPGA)等類型。它們的內(nèi)部結(jié)構(gòu)和表現(xiàn)方法各不相同可編程邏輯器件的分類1) 按編程部位分類PLD有
5、著大致相同的基本結(jié)構(gòu),根據(jù)與陣列或陣列是否可編程,分為三種基本類型:與陣列固定,或陣列可編程;2與或陣列均可編程;3與陣列可編程,或陣列固定2) 按編程方式分類1掩膜編程2熔絲與反熔絲編程;3紫外線擦除、電可編程;4電擦除、電可編程;5在系統(tǒng)編程(2)現(xiàn)場可編程門陣列(FPGA)現(xiàn)場可編程邏輯門陣列(FPGA, Field Programmable Gate Array),是一個含有可編輯元件的半導(dǎo)體設(shè)備,可供使用者現(xiàn)場程式化的邏輯門陣列元件。FPGA是在PAL、GAL、CPLD等可編輯器件的基礎(chǔ)上進(jìn)一步發(fā)展的產(chǎn)物。FPGA概述FPGA則是操控層次更低,所以自由度更大的芯片,對FPGA的編程在
6、編譯后是轉(zhuǎn)化為FPGA內(nèi)的連線表,相當(dāng)于FPGA內(nèi)提供了大量的與非門、或非門、觸發(fā)器(可以用與非門形成吧)等基本數(shù)字器件,編程決定了有多少器件被使用以及它們之間的連接。只要FPGA規(guī)模夠大,這些數(shù)字器件理論上能形成一切數(shù)字系統(tǒng),包括單片機甚至CPU。FPGA在抗干擾,速度上有很大優(yōu)勢。FPGA發(fā)展背景目前以硬件描述語言(Verilog 或 VHDL)所完成的電路設(shè)計,可以經(jīng)過簡單的綜合與布局,快速的燒錄至 FPGA 上進(jìn)行測試,是現(xiàn)代 IC 設(shè)計驗證的技術(shù)主流。這些可編輯元件可以被用來實現(xiàn)一些基本的邏輯門電路(比如AND、OR、XOR、NOT)或者更復(fù)雜一些的組合功能比如解碼器或數(shù)學(xué)方程式。在
7、大多數(shù)的FPGA里面,這些可編輯的元件里也包含記憶元件例如觸發(fā)器(Flipflop)或者其他更加完整的記憶塊。 系統(tǒng)設(shè)計師可以根據(jù)需要通過可編輯的連接把FPGA內(nèi)部的邏輯塊連接起來,就好像一個電路試驗板被放在了一個芯片里。一個出廠后的成品FPGA的邏輯塊和連接可以按照設(shè)計者而改變,所以FPGA可以完成所需要的邏輯功能。 FPGA一般來說比ASIC(專用集成芯片)的速度要慢,無法完成復(fù)雜的設(shè)計,而且消耗更多的電能。但是他們也有很多的優(yōu)點比如可以快速成品,可以被修改來改正程序中的錯誤和更便宜的造價。廠商也可能會提供便宜的但是編輯能力差的FPGA。因為這些芯片有比較差的可編輯能力,所以這些設(shè)計的開發(fā)
8、是在普通的FPGA上完成的,然后將設(shè)計轉(zhuǎn)移到一個類似于ASIC的芯片上。另外一種方法是用CPLD(復(fù)雜可編程邏輯器件備)。產(chǎn)品比較早在1980年代中期,F(xiàn)PGA已經(jīng)在PLD設(shè)備中扎根。CPLD和FPGA包括了一些相對大數(shù)量的可編輯邏輯單元。CPLD邏輯門的密度在幾千到幾萬個邏輯單元之間,而FPGA通常是在幾萬到幾百萬。CPLD和FPGA的主要區(qū)別是他們的系統(tǒng)結(jié)構(gòu)。CPLD是一個有點限制性的結(jié)構(gòu)。這個結(jié)構(gòu)由一個或者多個可編輯的結(jié)果之和的邏輯組列和一些相對少量的鎖定的寄存器組成。這樣的結(jié)果是缺乏編輯靈活性,但是卻有可以預(yù)計的延遲時間和邏輯單元對連接單元高比率的優(yōu)點。而FPGA卻是有很多的連接單元,
9、這樣雖然讓它可以更加靈活的編輯,但是結(jié)構(gòu)卻復(fù)雜的多。CPLD和FPGA另外一個區(qū)別是大多數(shù)的FPGA含有高層次的內(nèi)置模塊(比如加法器和乘法器)和內(nèi)置的記憶體。因此一個有關(guān)的重要區(qū)別是很多新的FPGA支持完全的或者部分的系統(tǒng)內(nèi)重新配置。允許他們的設(shè)計隨著系統(tǒng)升級或者動態(tài)重新配置而改變。一些FPGA可以讓設(shè)備的一部分重新編輯而其他部分繼續(xù)正常運行。CPLD和FPGA還有一個區(qū)別:CPLD下電之后,原有燒入的邏輯結(jié)構(gòu)不會消失;而FPGA下電之后,再次上電時,需要重新加載FLASH里面的邏輯代碼,需要一定的加載時間。發(fā)展歷程每一個后看來很成功的新事物,從誕生到發(fā)展壯大都不可避免地經(jīng)歷過艱難的歷程,并可
10、能成為被研究的案例,F(xiàn)PGA也不例外。1985年,當(dāng)全球首款FPGA產(chǎn)品XC2064誕生時,注定要使用大量芯片的PC機剛剛走出硅谷的實驗室進(jìn)入商業(yè)市場,因特網(wǎng)只是科學(xué)家和政府機構(gòu)通信的神秘鏈路,無線電話笨重得像磚頭,日后大紅大紫的BillGates正在為生計而奮斗,創(chuàng)新的可編程產(chǎn)品似乎并沒有什么用武之地。事實也的確如此。最初,F(xiàn)PGA只是用于膠合邏輯(GlueLogic),從膠合邏輯到算法邏輯再到數(shù)字信號處理、高速串行收發(fā)器和嵌入式處理器,F(xiàn)PGA真正地從配角變成了主角。在以閃電般速度發(fā)展的半導(dǎo)體產(chǎn)業(yè)里,22年足夠改變一切?!霸谖磥硎陜?nèi)每一個電子設(shè)備都將有一個可編程邏輯芯片”的理想正成為現(xiàn)實
11、。1985年,Xilinx公司推出的全球第一款FPGA產(chǎn)品XC2064怎么看都像是一只“丑小鴨”采用2m工藝,包含64個邏輯模塊和85000個晶體管,門數(shù)量不超過1000個。22年后的2007年,F(xiàn)PGA業(yè)界雙雄Xilinx和Altera公司紛紛推出了采用最新65nm工藝的FPGA產(chǎn)品,其門數(shù)量已經(jīng)達(dá)到千萬級,晶體管個數(shù)更是超過10億個。一路走來,F(xiàn)PGA在不斷地緊跟并推動著半導(dǎo)體工藝的進(jìn)步2001年采用150nm工藝、2002年采用130nm工藝,2003年采用90nm工藝,2006年采用65nm工藝。在上世紀(jì)80年代中期,可編程器件從任何意義上來講都不是當(dāng)時的主流,雖然其并不是一個新的概念
12、??删幊踢壿嬯嚵?PLA)在1970年左右就出現(xiàn)了,但是一直被認(rèn)為速度慢,難以使用。1980年之后,可配置可編程邏輯陣列(PAL)開始出現(xiàn),可以使用原始的軟件工具提供有限的觸發(fā)器和查找表實現(xiàn)能力。PAL被視為小規(guī)模/中等規(guī)模集成膠合邏輯的替代選擇被逐步接受,但是當(dāng)時可編程能力對于大多數(shù)人來說仍然是陌生和具有風(fēng)險的。20世紀(jì)80年代在“megaPAL”方面的嘗試使這一情況更加嚴(yán)重,因為“megaPAL”在功耗和工藝擴展方面有嚴(yán)重的缺陷,限制了它的廣泛應(yīng)用。然而,Xilinx公司創(chuàng)始人之一FPGA的發(fā)明者RossFreeman認(rèn)為,對于許多應(yīng)用來說,如果實施得當(dāng)?shù)脑?,靈活性和可定制能力都是具有吸引
13、力的特性。也許最初只能用于原型設(shè)計,但是未來可能代替更廣泛意義上的定制芯片。事實上,正如Xilinx公司亞太區(qū)營銷董事鄭馨南所言,隨著技術(shù)的不斷發(fā)展,F(xiàn)PGA由配角到主角,很多系統(tǒng)設(shè)計都是以FPGA為中心來設(shè)計的。FPGA走過了從初期開發(fā)應(yīng)用到限量生產(chǎn)應(yīng)用再到大批量生產(chǎn)應(yīng)用的發(fā)展歷程。從技術(shù)上來說,最初只是邏輯器件,現(xiàn)在強調(diào)平臺概念,加入數(shù)字信號處理、嵌入式處理、高速串行和其他高端技術(shù),從而被應(yīng)用到更多的領(lǐng)域?!?0年代以來的20年間,PLD產(chǎn)品的終極目標(biāo)一直瞄準(zhǔn)速度、成本和密度三個指標(biāo),即構(gòu)建容量更大、速度更快和價格更低的FPGA,讓客戶能直接享用。”Actel司總裁兼首席執(zhí)行官JohnEa
14、st如此總結(jié)可編程邏輯產(chǎn)業(yè)的發(fā)展脈絡(luò)。當(dāng)1991年Xilinx公司推出其第三代FPGA產(chǎn)品XC4000系列時,人們開始認(rèn)真考慮可編程技術(shù)了。XC4003包含44萬個晶體管,采用0.7m工藝,F(xiàn)PGA開始被制造商認(rèn)為是可以用于制造工藝開發(fā)測試過程的良好工具。事實證明,F(xiàn)PGA可為制造工業(yè)提供優(yōu)異的測試能力,F(xiàn)PGA開始用來代替原先存儲器所扮演的用來驗證每一代新工藝的角色。也許從那時起,向最新制程半導(dǎo)體工藝的轉(zhuǎn)變就已經(jīng)不可阻擋了。最新工藝的采用為FPGA產(chǎn)業(yè)的發(fā)展提供了機遇。Actel公司相信,F(xiàn)lash將繼續(xù)成為FPGA產(chǎn)業(yè)中重要的一個增長領(lǐng)域。Flash技術(shù)有其獨特之處,能將非易失性和可重編程
15、性集于單芯片解決方案中,因此能提供高成本效益,而且處于有利的位置以搶占龐大的市場份額。Actel以Flash技術(shù)為基礎(chǔ)的低功耗IGLOO系列、低成本的ProASIC3系列和混合信號Fusion FPGA將因具備Flash的固有優(yōu)勢而繼續(xù)引起全球廣泛的興趣和注意。Altera公司估計可編程邏輯器件市場在2006年的規(guī)模大概為37億美元,Xilinx公司的估計更為樂觀一些,為50億美元。雖然兩家公司合計占據(jù)該市場90%的市場份額,但是作為業(yè)界老大的Xilinx公司在2006年的營收不過18.4億美元,Altera公司則為12.9億美元。PLD市場在2000年達(dá)到41億美元,其后兩年出現(xiàn)了下滑,20
16、02年大約為23億美元。雖然從2002年到2006年,PLD市場每年都在增長,復(fù)合平均增長率接近13%,但是PLD終究是一個規(guī)模較小的市場。而Xilinx公司也敏銳地意識到,F(xiàn)PGA產(chǎn)業(yè)在經(jīng)歷了過去幾年的快速成長后將放慢前進(jìn)的腳步,那么,未來FPGA產(chǎn)業(yè)的出路在哪里?Altera公司總裁兼首席執(zhí)行官John Daane認(rèn)為,F(xiàn)PGA及PLD產(chǎn)業(yè)發(fā)展的最大機遇是替代ASIC和專用標(biāo)準(zhǔn)產(chǎn)品(ASSP),主要由ASIC和ASSP構(gòu)成的數(shù)字邏輯市場規(guī)模大約為350億美元。由于用戶可以迅速對PLD進(jìn)行編程,按照需求實現(xiàn)特殊功能,與ASIC和ASSP相比,PLD在靈活性、開發(fā)成本以及產(chǎn)品及時面市方面更具優(yōu)
17、勢。然而,PLD通常比這些替代方案有更高的成本結(jié)構(gòu)。因此,PLD更適合對產(chǎn)品及時面市有較大需求的應(yīng)用,以及產(chǎn)量較低的最終應(yīng)用。PLD技術(shù)和半導(dǎo)體制造技術(shù)的進(jìn)步,從總體上縮小了PLD和固定芯片方案的相對成本差,在以前由ASIC和ASSP占據(jù)的市場上,Altera公司已經(jīng)成功地提高了PLD的銷售份額,并且今后將繼續(xù)這一趨勢?!癋PGA和PLD供應(yīng)商的關(guān)鍵目標(biāo)不是簡單地增加更多的原型客戶,而是向大批量應(yīng)用最終市場和客戶滲透?!盝ohn Daane為FPGA產(chǎn)業(yè)指明了方向。理念成熟Xilinx公司認(rèn)為,ASIC SoC設(shè)計周期平均是14個月到24個月,用FPGA進(jìn)行開發(fā)時間可以平均降低55%。而產(chǎn)品晚
18、上市六個月5年內(nèi)將少33%的利潤,每晚四周等于損失14%的市場份額。因此,鄭馨南雄心勃勃地預(yù)言:“FPGA應(yīng)用將不斷加快,從面向50億美元的市場擴展到面向410億美元的市場。”其中,ASIC和ASSP市場各150億美元,嵌入式處理和高性能DSP市場各30億美元。雖然沒有像蒸汽機車發(fā)明之初備受嘲笑被譏諷為“怪物”,但是FPGA在誕生之初受到懷疑是毫無疑問的。當(dāng)時,晶體管邏輯門資源極為珍貴,每個人都希望用到的晶體管越少越好。不過,Ross Freeman挑戰(zhàn)了這一觀念,他大膽預(yù)言:“在未來,晶體管將變得極為豐富從而可以免費使用?!比缃?,這一預(yù)言成為現(xiàn)實。“FPGA非常適用于原型設(shè)計,但對于批量DS
19、P系統(tǒng)應(yīng)用來說,成本太高,功耗太大。”這是業(yè)界此前的普遍觀點,很長時間以來也為FPGA進(jìn)入DSP領(lǐng)域設(shè)置了觀念上的障礙。而如今,隨著Xilinx公司和Altera公司相關(guān)產(chǎn)品的推出,DSP領(lǐng)域已經(jīng)不再是FPGA的禁區(qū),相反卻成了FPGA未來的希望所在。FPGA對半導(dǎo)體產(chǎn)業(yè)最大的貢獻(xiàn)莫過于創(chuàng)立了無生產(chǎn)線(Fabless)模式。如今采用這種模式司空見慣,但是在20多年前,制造廠被認(rèn)為是半導(dǎo)體芯片企業(yè)必須認(rèn)真考慮的主要競爭優(yōu)勢。然而,基于過去和關(guān)系和直接、清晰的業(yè)務(wù)模式,Xilinx創(chuàng)始人之一Bernie Vonderschmitt成功地使日本精工公司(Seiko)確信利用該公司的制造設(shè)施來生產(chǎn)Xi
20、linx公司設(shè)計的芯片對雙方都是有利的,于是,無生產(chǎn)線模式誕生了。未來,相信FPGA還將在更多方面改變半導(dǎo)體產(chǎn)業(yè)!CPLD與FPGA的關(guān)系早在1980年代中期,F(xiàn)PGA已經(jīng)在PLD設(shè)備中扎根。CPLD和FPGA包括了一些相對大數(shù)量的可以編輯邏輯單元。CPLD邏輯門的密度在幾千到幾萬個邏輯單元之間,而FPGA通常是在幾萬到幾百萬。 CPLD和FPGA的主要區(qū)別是他們的系統(tǒng)結(jié)構(gòu)。CPLD是一個有點限制性的結(jié)構(gòu)。這個結(jié)構(gòu)由一個或者多個可編輯的結(jié)果之和的邏輯組列和一些相對少量的鎖定的寄存器。這樣的結(jié)果是缺乏編輯靈活性,但是卻有可以預(yù)計的延遲時間和邏輯單元對連接單元高比率的優(yōu)點。而FPGA卻是有很多的連
21、接單元,這樣雖然讓它可以更加靈活的編輯,但是結(jié)構(gòu)卻復(fù)雜的多。 CPLD和FPGA另外一個區(qū)別是大多數(shù)的FPGA含有高層次的內(nèi)置模塊(比如加法器和乘法器)和內(nèi)置的記憶體。一個因此有關(guān)的重要區(qū)別是很多新的FPGA支持完全的或者部分的系統(tǒng)內(nèi)重新配置。允許他們的設(shè)計隨著系統(tǒng)升級或者動態(tài)重新配置而改變。一些FPGA可以讓設(shè)備的一部分重新編輯而其他部分繼續(xù)正常運行。FPGA工作原理FPGA采用了邏輯單元陣列LCA(Logic Cell Array)這樣一個概念,內(nèi)部包括可配置邏輯模塊CLB(Configurable Logic Block)、輸出輸入模塊IOB(Input Output Block)和內(nèi)部
22、連線(Interconnect)三個部分。FPGA的基本特點· 1)采用FPGA設(shè)計ASIC電路(特定用途集成電路),用戶不需要投片生產(chǎn),就能得到合用的芯片。2)FPGA可做其它全定制或半定制ASIC電路的中試樣片。3)FPGA內(nèi)部有豐富的觸發(fā)器和IO引腳。4)FPGA是ASIC電路中設(shè)計周期最短、開發(fā)費用最低、風(fēng)險最小的器件之一。5) FPGA采用高速CHMOS工藝,功耗低,可以與CMOS、TTL電平兼容??梢哉f,F(xiàn)PGA芯片是小批量系統(tǒng)提高系統(tǒng)集成度、可靠性的最佳選擇之一。FPGA是由存放在片內(nèi)RAM中的程序來設(shè)置其工作狀態(tài)的,因此,工作時需要對片內(nèi)的RAM進(jìn)行編程。用戶可以根據(jù)
23、不同的配置模式,采用不同的編程方式。加電時,F(xiàn)PGA芯片將EPROM中數(shù)據(jù)讀入片內(nèi)編程RAM中,配置完成后,F(xiàn)PGA進(jìn)入工作狀態(tài)。掉電后,F(xiàn)PGA恢復(fù)成白片,內(nèi)部邏輯關(guān)系消失,因此,F(xiàn)PGA能夠反復(fù)使用。FPGA的編程無須專用的FPGA編程器,只須用通用的EPROM、PROM編程器即可。當(dāng)需要修改FPGA功能時,只需換一片EPROM即可。這樣,同一片F(xiàn)PGA,不同的編程數(shù)據(jù),可以產(chǎn)生不同的電路功能。因此,F(xiàn)PGA的使用非常靈活。FPGA配置模式· FPGA有多種配置模式:并行主模式為一片F(xiàn)PGA加一片EPROM的方式;主從模式可以支持一片PROM編程多片F(xiàn)PGA;串行模式可以采用串行
24、PROM編程FPGA;外設(shè)模式可以將FPGA作為微處理器的外設(shè),由微處理器對其編程。如何實現(xiàn)快速的時序收斂、降低功耗和成本、優(yōu)化時鐘管理并降低FPGA與PCB并行設(shè)計的復(fù)雜性等問題,一直是采用FPGA的系統(tǒng)設(shè)計工程師需要考慮的關(guān)鍵問題。如今,隨著FPGA向更高密度、更大容量、更低功耗和集成更多IP的方向發(fā)展,系統(tǒng)設(shè)計工程師在從這些優(yōu)異性能獲益的同時,不得不面對由于FPGA前所未有的性能和能力水平而帶來的新的設(shè)計挑戰(zhàn)。例如,領(lǐng)先FPGA廠商Xilinx最近推出的Virtex-5系列采用65nm工藝,可提供高達(dá)33萬個邏輯單元、1,200個I/O和大量硬IP塊。超大容量和密度使復(fù)雜的布線變得更加不
25、可預(yù)測,由此帶來更嚴(yán)重的時序收斂問題。此外,針對不同應(yīng)用而集成的更多數(shù)量的邏輯功能、DSP、嵌入式處理和接口模塊,也讓時鐘管理和電壓分配問題變得更加困難。幸運地是,F(xiàn)PGA廠商、EDA工具供應(yīng)商正在通力合作解決65nm FPGA獨特的設(shè)計挑戰(zhàn)。不久以前,Synplicity與Xilinx宣布成立超大容量時序收斂聯(lián)合工作小組,旨在最大程度地幫助系統(tǒng)設(shè)計工程師以更快、更高效的方式應(yīng)用65nm FPGA器件。設(shè)計軟件供應(yīng)商Magma推出的綜合工具Blast FPGA能幫助建立優(yōu)化的布局,加快時序的收斂。最近FPGA的配置方式已經(jīng)多元化!FPGA的應(yīng)用· 微處理器是為通用而設(shè)計的,必須按照時
26、鐘的節(jié)拍,逐條取指、譯指、執(zhí)行,大多用于低速、實時性要求不高的場合,例如石油探測;FPGA 應(yīng)用場合相當(dāng)多,特別是在高速的、實時性強并對時間要求相當(dāng)苛刻的場合,有很強的數(shù)據(jù)處理能力,例如無線通信、雷達(dá)探測等;是FPGA的一些典型應(yīng)用:典型應(yīng)用一:接口邏輯控制提供前所未有的靈活性1、PCI、PCI Express、PS/2、USB等接口控制器2、SDRAM、DDR、SDRAM、QDR、SRAM、NAND Flash、NOR Flash等接口控制器3、電平轉(zhuǎn)換,LVDS、TTL、COMS、SSTL等典型應(yīng)用二:高速的數(shù)字信號處理提供前所未有的計算能力1、無線通信領(lǐng)域,如軟件無線電(SDR);2、視
27、頻圖像處理領(lǐng)域,如高清晰數(shù)字電視(HDTV);3、軍事和航空航天領(lǐng)域,如雷達(dá)聲納、安全通信。其他應(yīng)用領(lǐng)域1、汽車,如網(wǎng)關(guān)控制器、車用PC、遠(yuǎn)程信息處理系統(tǒng)等;2、消費產(chǎn)品,如顯示器/投影儀、數(shù)字電視和機頂盒、家庭網(wǎng)絡(luò)等;3、醫(yī)療,如電療、血液分析儀、醫(yī)療檢測設(shè)備等4、通信設(shè)備 ,如蜂窩基礎(chǔ)設(shè)施、寬帶無線通信、軟件無線電等5、測試與測量,如通信測試與監(jiān)測、半導(dǎo)體、自動測試設(shè)備、通用儀表等。2.FPGA時序設(shè)計與時序分析FPGA設(shè)計一個很重要的設(shè)計是時序設(shè)計,而時序設(shè)計的實質(zhì)就是滿足每一個觸發(fā)器的建立(Setup)/保持(Hold)時間的要求。 建立時間(Set
28、up Time):是指在觸發(fā)器的時鐘信號上升沿到來以前,數(shù)據(jù)穩(wěn)定不變的時間,如果建立時間不夠,數(shù)據(jù)將不能在這個時鐘上升沿被打入觸發(fā)器; 保持時間(Hold Time):是指在觸發(fā)器的時鐘信號上升沿到來以后,數(shù)據(jù)穩(wěn)定不變的時間, 如果保持時間不夠,數(shù)據(jù)同樣不能被打入觸發(fā)器。 FPGA設(shè)計分為異步電路設(shè)計和同步電路設(shè)計,然而很多異步電路設(shè)計都可以轉(zhuǎn)化為同步電路設(shè)計,在設(shè)計時盡量采用同步電路進(jìn)行設(shè)計。對于同步電路可以轉(zhuǎn)化的邏輯必須轉(zhuǎn)化,不能轉(zhuǎn)化的邏輯,應(yīng)將異步的部分減到最小,而其前
29、后級仍然應(yīng)該采用同步設(shè)計。 為了讓同步電路可靠地運行,就要對時鐘偏差進(jìn)行控制,以使時鐘偏差減小到可用的范圍。影響時鐘偏差的主要有以下幾個因素:o 用于連接時鐘樹的連線o 鐘樹的拓?fù)浣Y(jié)構(gòu)o 時鐘的驅(qū)動o 時鐘線的負(fù)載o 時鐘的上升及下降時間 在通常的FPGA設(shè)計中對時鐘偏差的控制主要有以下幾種方法:o 控 制時鐘信號盡量走可編程器件的的全局時鐘網(wǎng)絡(luò)。在可編程器件中一般都有專門的時鐘驅(qū)動器及全局時鐘網(wǎng)絡(luò),不同種類、型號的可編程器件,它們中的全局時鐘網(wǎng) 絡(luò)數(shù)量不同,因此要根據(jù)不同的設(shè)計需要選擇含有合適數(shù)量全局時鐘網(wǎng)絡(luò)的可編程器件。
30、一般來說,走全局時鐘網(wǎng)絡(luò)的時鐘信號到各使用端的延時小,時鐘偏差很 小,基本可以忽略不計。o 若設(shè)計中時鐘信號數(shù)量很多,無法讓所有的信號都走全局時鐘網(wǎng)絡(luò),那么可以通過在設(shè)計中加約束的方法,控制不能走全局時鐘網(wǎng)絡(luò)的時鐘信號的時鐘偏差。o 異步接口時序裕度要足夠大。局部同步電路之間接口都可以看成是異步接口,比較典型的是設(shè)計中的高低頻電路接口、I/O接口,那么接口電路中后一級觸發(fā)器的建立-保持時間要滿足要求,時序裕度要足夠大。o 在系統(tǒng)時鐘大于30MHz時,設(shè)計難度有所加大,建議采用流水線等設(shè)計方法。采用流水線處理方式可以達(dá)到提高時序電路的速度,但使用的器件資源也成倍增加。o 要保證電路設(shè)計的理論最高
31、工作頻率大于電路的實際工作頻率。A 時序約束的概念和基本策略時序約束主要包括周期約束(FFS到FFS,即觸發(fā)器到觸發(fā)器)和偏移約束(IPAD到FFS、FFS到OPAD)以及靜態(tài)路徑約束(IPAD到 OPAD)等3種。通過附加約束條件可以使綜合布線工具調(diào)整映射和布局布線過程,使設(shè)計達(dá)到時序要求。例如用OFFSET_IN_BEFORE約束可以告 訴綜合布線工具輸入信號在時鐘之前什么時候準(zhǔn)備好,綜合布線工具就可以根據(jù)這個約束調(diào)整與IPAD相連的Logic Circuitry的綜合實現(xiàn)過程,使結(jié)果滿足FFS的建立時間要求。附加時序約束的一般策略是先附加全局約束,然后對快速和慢速例外路徑附加專門約束。附
32、加全局約束時,首先定義設(shè)計的所有時鐘,對各時鐘域內(nèi)的同步元件進(jìn)行 分組,對分組附加周期約束,然后對FPGA/CPLD輸入輸出PAD附加偏移約束、對全組合邏輯的PAD TO PAD路徑附加約束。附加專門約束時,首先約束分組之間的路徑,然后約束快、慢速例外路徑和多周期路徑,以及其他特殊路徑。B 附加約束的基本作用提高設(shè)計的工作頻率對很多數(shù)字電路設(shè)計來說,提高工作頻率非常重要,因為高工作頻率意味著高處理能力。通過附加約束可以控制邏輯的綜合、映射、布局和布線,以減小邏輯和布線延時,從而提高工作頻率。 獲得正確的時序分析報告幾乎所有的FPGA設(shè)計平臺都包含靜態(tài)時序分析工具,利用這類工具可以獲得映射或布局
33、布線后的時序分析報告,從而對設(shè)計的性能做出評估。靜態(tài)時序分析工具以約束作為判斷時序是否滿足設(shè)計要求的標(biāo)準(zhǔn),因此要求設(shè)計者正確輸入約束,以便靜態(tài)時序分析工具輸出正確的時序分析報告。 1. 指定FPGA/CPLD引腳位置與電氣標(biāo)準(zhǔn)FPGA/CPLD的可編程特性使電路板設(shè)計加工和FPGA/CPLD設(shè)計可以同時進(jìn)行,而不必等FPGA/CPLD引腳位置完全確定,從而節(jié)省了系統(tǒng)開發(fā)時間。這樣,電路板加工完成后,設(shè)計者要根據(jù)電路板的走線對FPGA/CPLD加上引腳位置約束,使FPGA/CPLD與電路板正確連接。另外通過約束還可以指定IO引腳所支持的接口標(biāo)準(zhǔn)和其他電氣特性。為了滿足日新月異的通信發(fā)展,Xili
34、nx新型FPGA/CPLD可以通過IO引腳約束設(shè)置支持諸如 AGP、BLVDS、CTT、GTL、GTLP、HSTL、LDT、LVCMOS、LVDCI、LVDS、LVPECL、LVDSEXT、LVTTL、 PCI、PCIX、SSTL、ULVDS等豐富的IO接口標(biāo)準(zhǔn)。另外通過區(qū)域約束還能在FPGA上規(guī)劃各個模塊的實現(xiàn)區(qū)域,通過物理布局布線約束,完成模 塊化設(shè)計等。 C 周期(PERIOD)的含義周期的含義是時序中最簡單也是最重要的含義,其它很多時序概念會因為軟件商不同略有差異,而周期的概念確是最通用的,周期的概念是FPGA/ASIC時序定義的基礎(chǔ)概念。后面要講到的其它時序約束都是建立在周期約束的基
35、礎(chǔ)上的,很多其它時序公式,可以用周期公式推導(dǎo)。周期約束是一個基本時序和綜合約束,它附加在時鐘網(wǎng)線上,時序分析工具根據(jù)PERIOD約束檢查時鐘域內(nèi)所有同步元件的時序是否滿足要求。PERIOD約束會自動處理寄存器時鐘端的反相問題, 如果相鄰?fù)皆r鐘相位相反,那么它們之間的延遲將被默認(rèn)限制為PERIOD約束值的一半。如下圖所示,圖1 周期的定義 時鐘的最小周期為:TCLK = TCKO +TLOGIC +TNET +TSETUP TCLK_SKEWTCLK_SKEW =TCD2 TCD1其中TCKO為時鐘輸出時間,TLOGIC為同步元件之間的組合邏輯延遲,TN
36、ET為網(wǎng)線延遲,TSETUP為同步元件的建立時間,TCLK_SKEW為時鐘信號TCD2和TCD1延遲的差別。D 數(shù)據(jù)和時鐘之間的約束為了確保芯片數(shù)據(jù)采樣可靠和下級芯片之間正確地交換數(shù)據(jù),需要約束外部時鐘和數(shù)據(jù)輸入輸出引腳之間的時序關(guān)系(或者內(nèi)部時鐘和外部輸入/輸出數(shù)據(jù)之間的關(guān)系,這僅僅是從采用了不同的參照系罷了)。約束的內(nèi)容為告訴綜合器、布線器輸入數(shù)據(jù)到達(dá)的時刻,或者輸出數(shù)據(jù)穩(wěn)定的時刻,從而保證與下一級電路的時序關(guān)系。這種時序約束在Xilinx中用Setup to Clock(edge),Clock(edge) to hold等表示。在Altera里常用tsu (Input Setup Tim
37、es)、th (Input Hold Times)、tco (Clock to Out Delays)來表示。很多其它時序工具直接用setup和hold表示。其實他們所要描述的是同一個問題,僅僅是時間節(jié)點的定義上略有不同。下面依次介 紹。E 關(guān)于輸入到達(dá)時間Xilinx的"輸入到達(dá)時間的計算"時序描述如下圖所示:圖2 輸入到達(dá)時間示意圖 定義的含義是輸入數(shù)據(jù)在有效時鐘沿之后的TARRIVAL時刻到達(dá)。則,TARRIVAL=TCKO+TOUTPUT+TLOGIC 公式1 根據(jù)上面介紹的周期(Period)
38、公式,我們可以得到:Tcko+Toutput+Tlogic+Tinput+Tsetup-Tclk_skew=Tclk; 公式2 將公式1代入公式2: Tarrival+Tinput+Tsetup-Tclk_skew=Tclk, 而Tclk_skew滿足時序關(guān)系后為負(fù),所以TARRIVAL +TINPUT+TSETUP <TCLK 公式3 這就是Tarrival應(yīng)該滿足的時序關(guān)系。其中TINPUT為輸入端的組合邏輯、網(wǎng)線和PAD的延遲之和,TSETUP為輸入同步元件的建立時間。F 數(shù)
39、據(jù)延時和數(shù)據(jù)到達(dá)時間的關(guān)系圖3 數(shù)據(jù)延時和數(shù)據(jù)到達(dá)時間示意圖TDELAY為要求的芯片內(nèi)部輸入延遲,其最大值TDELAY_MAX與輸入數(shù)據(jù)到達(dá)時間TARRIVAL的關(guān)系如上圖所示。也就是說: TDELAY_MAX+TARRIVAL=TPERIOD 公式4 所以:TDELAY<TDELAY_MAX=TPERIODTARRIVALG 要求輸出的穩(wěn)定時間從下一級輸入端的延遲可以計算出當(dāng)前設(shè)計輸出的數(shù)據(jù)必須在何時穩(wěn)定下來,根據(jù)這個數(shù)據(jù)對設(shè)計輸出端的邏輯布線進(jìn)行約束,以滿足下一級的建立時間要求,保證下一級采樣的數(shù)據(jù)是穩(wěn)定的。計算要求的輸出穩(wěn)定時間如下圖所示:圖4
40、要求的輸出穩(wěn)定時間示意圖公式的推導(dǎo)如下: 定義:TSTABLE = TLOGIC +TINPUT +TSETUP 從前面帖子介紹的周期(Period)公式,可以得到(其中TCLK_SKEWTCLK1TCLK2):TCLKTCKOTOUTPUT+TLOGIC+TINPUT+TSETUP+TCLK_SKEW將TSTABLE的定義代入到周期公式,可以得到:TCLK=TCKO+TOUTPUT+TSTABLE+TCLK_SKEW 所以:TCKO +TOUTPUT+TSTABLE<TCLK 這個公式就是TSTABLE必須要滿足的基本時序關(guān)系,即本級的輸出應(yīng)該保持怎么樣的穩(wěn)定狀態(tài),才能保證下級芯片的采
41、樣穩(wěn)定。有時我們也稱這個約束關(guān)系是 輸出數(shù)據(jù)的保持時間的時序約束關(guān)系。只要滿足上述關(guān)系,當(dāng)前芯片輸出端的數(shù)據(jù)比時鐘上升沿提早TSTABLE 時間穩(wěn)定下來,下一級就可以正確地采樣數(shù)據(jù)。其中TOUTPUT為設(shè)計中連接同步元件輸出端的組合邏輯、網(wǎng)線和PAD的延遲之和,TCKO為同步元件時鐘輸出時間。H 實施時序約束的方法和命令 實施上述約束的基本方法是,根據(jù)已知時序信息,推算需要約束的時間值,實施約束。具體地說是這樣的,首先對于一般設(shè)計,首先掌握的是TCLK,這個對于設(shè)計者來說是個已知量。前面介紹公式和圖中的TCKO和TSETUP(注:有的工具軟件對TCKO和TS
42、ETUP的定義與前面圖形不同,還包含了到達(dá)同步器件的一段logic的時延)是器件內(nèi)部固有的一個時間量,一般我們選取典型值,對于FPGA,這個量值比較小,一般不大于12ns。比較難以確定的是TINPUT和TOUTPUT兩個時間量。約束輸入時間偏移,需要知道TINPUT,TINPUT為輸入端的組合邏輯、網(wǎng)線和PAD的延遲之和,PAD的延時也根據(jù)器件型號也有典型值可選,但是到 達(dá)輸入端的組合邏輯電路和網(wǎng)線的延時就比較難以確定了,只能通過靜態(tài)時序分析工具分析,或者通過底層布局布線工具量取,有很大的經(jīng)驗和試探的成分在里面。 約束輸出時間偏移,需要知道TOUTPUT,TOUTPUT為設(shè)計中連接同步元件輸出
43、端的組合邏輯、網(wǎng)線和PAD的延遲之和,仍然是到達(dá)輸出端的組合邏輯 電路和網(wǎng)線的延時就比較難以確定,需要通過靜態(tài)時序分析工具分析,或者通過底層布局布線工具量取,有很大的經(jīng)驗和試探的成分在里面。約束的具體命令根據(jù)約束工具不同而異,首先說使用Xilinx器件的情況下,實施上述約束的命令和方法。Xilinx把上述約束統(tǒng)稱為:OFFSET約束 (偏移約束),一共有4個相關(guān)約束屬性:OFFSET_IN_BEFORE、OFFSET_IN_AFTER、OFFSET_OUT_BEFORE和 OFFSET_OUT_AFTER。其中前兩個屬性叫做輸入偏移(OFFSET_IN)約束,基本功能相似,僅僅是約束取的參考對
44、象不同而已。后兩個屬性 叫做輸出偏移(OFFSET_OUT)約束,基本功能相似,也是約束取的參考對象不同而已。為了便于理解,舉例說明。輸入偏移約束:時鐘周期為20ns,前級寄存器的TCKO選擇1ns,前級輸出邏輯延時TOUTPUT為3ns,中間邏輯TLOGIC的延時為10ns, 那么TARRIVAL=14ns,于是可以在數(shù)據(jù)輸入引腳附加NET DATA_IN OFFET=IN 14ns AFTER CLK約束,也可以使用OFFSET_IN_BEFORE對芯片內(nèi)部的輸入邏輯進(jìn)行約束,其語法如下:NET DATA_IN OFFET=IN TDELAY BEFORE CLK 其中TDELAY為要求的
45、芯片內(nèi)部輸入延遲,其最大值與輸入數(shù)據(jù)到達(dá)時間TARRIVAL的關(guān)系:TDELAY_MAX + TARRIVAL = TPERIOD,所以TDELAY < TPERIOD - TARRIVAL = 20 - 14 =6 ns。輸出偏移約束:設(shè)時鐘周期為20ns,后級輸入邏輯延時TINPUT為4ns、建立時間TSETUP為1ns,中間邏輯TLOGIC的延時為10ns,那 么TSTABLE=15ns,于是可以在數(shù)據(jù)輸入引腳附加NET DATA_OUT OFFET=OUT 15ns BEFORE CLK約束,也可以直接對芯片內(nèi)部的輸出邏輯直接進(jìn)行約束,NET DATA_OUT OFFET=OUT
46、 TOUTPUT_DELAY AFTER CLK,其中TOUTPUT_DELAY為要求的芯片內(nèi)部輸出延遲,其最大值與要求的輸出數(shù)據(jù)穩(wěn)定時間TSTABLE的關(guān)系為:TOUTPUT_DELAY_MAX+TSTABLE= TPERIOD。 TOUT_DELAY< TPERIOD - TSTABLE = 20 - 15 = 5nsI Altera對應(yīng)的時序概念下面主要介紹Altera對應(yīng)的這些時序概念和約束方法。 前面首先介紹的第一個時序概念是周期(Period),這個概念是FPGA/ASIC通用的一個概念,各方的定義相當(dāng)統(tǒng)一,至多是描述方式不同罷了,所有 的FPGA設(shè)計都首先要進(jìn)行周期約束,這
47、樣做的好處除了在綜合與布局布線時給出規(guī)定目標(biāo)外,還能讓時序分析工具考察整個設(shè)計的Fmax等。 Altera的周期定義如下圖所示,公式描述如下: 圖5 Altera 的 Period 示意圖Clock Period = Clk-to-out + Data Delay + Setup Time - Clk Skew即,Tclk= Tco+ B + Tsu-(E-C) Fmax =1/Tclk 對比一下前面的介紹,只要理解了B 包含了兩級寄存器之間的所有 logic 和 net 的延時就會發(fā)現(xiàn)與前面公式完全一致。J Altera的其他基本時序概念Clock Setup Time (tsu) 要想正確
48、采樣數(shù)據(jù),就必須使數(shù)據(jù)和使能信號在有效時鐘沿到達(dá)前就準(zhǔn)備好,所謂時鐘建立時間就是指時鐘到達(dá)前,數(shù)據(jù)和使能已經(jīng)準(zhǔn)備好的最小時間間隔。如下圖所示:圖6 tsu示意圖(注:這里定義Setup時間是站在同步時序整個路徑上的,需要區(qū)別的是另一個概念Micro tsu。Micro tsu指的是一個觸發(fā)器內(nèi)部的建立時間,它是觸發(fā)器的固有屬性,一般典型值小于12ns。在Xilinx等的時序概念中,稱Altera的Micro tsu為setup時間,用Tsetup表示,請大家區(qū)分一下。 回到Altera的時序概念,Altera的tsu定義如下: tsu = Data Delay Clock Delay + Mi
49、cro tsu)Clock Hold Time (tH) 時鐘保持時間是只能保證有效時鐘沿正確采用的數(shù)據(jù)和使能信號的最小穩(wěn)定時間。其定義如下圖所示:圖7 tH示意圖 定義的公式為: tH= Clock Delay Data Delay + Micro tH注:其中Micro tH是指寄存器內(nèi)部的固有保持時間,同樣是寄存器的一個固有參數(shù),典型值小于12ns。Clock-to-Output Delay(tco) 這個時間指的是當(dāng)時鐘有效沿變化后,將數(shù)據(jù)推倒同步時序路徑的輸出端的最小時間間隔。如下圖所示:圖8 tco示意圖tco Clock Delay + Mic
50、ro tco + Data Delay(注:其中 Micor tco也是一個寄存器的固有屬性,指的是寄存器相應(yīng)時鐘有效沿,將數(shù)據(jù)送到輸出端口的內(nèi)部時間參數(shù)。它與Xilinx的時序定義中,有一個概念叫Tcko是同一個概念。)Pin to Pin Delay (tpd) tpd指輸入管腳通過純組合邏輯到達(dá)輸出管腳這段路徑的延時,特別需要說明的是,要求輸入到輸出之間只有組合邏輯,才是tpd延時。Slack是表示設(shè)計是否滿足時序的一個稱謂,正的slack表示滿足時序(時序的余量),負(fù)的slack表示不滿足時序(時序的欠缺量)。slack的定義和圖形如下圖所示。圖9 slack示意圖 Slack = R
51、equired clock period Actual clock period Slack = Slack clock period (Micro tCO+ Data Delay + Micro tSU)Clock Skew指一個同源時鐘到達(dá)兩個不同的寄存器時鐘端的時間偏移,如下圖所示。圖10 clock skew示意圖基于FPGA的時序及同步設(shè)計2010-06-07 22:25數(shù)字電路中,時鐘是整個電路最重要、最特殊的信號。第一, 系統(tǒng)內(nèi)大部分器件的動作都是在時鐘的跳變沿上進(jìn)行, 這就要求時鐘信號時延差要非常小, 否則就可能造成時序邏輯狀態(tài)出錯.第二, 時鐘信號通常是系統(tǒng)中頻率最高的信號.
52、第三, 時鐘信號通常是負(fù)載最重的信號, 所以要合理分配負(fù)載。出于這樣的考慮在FPGA這類可編程器件內(nèi)部一般都設(shè)有數(shù)量不等的專門用于系統(tǒng)時鐘驅(qū)動的全局時鐘網(wǎng)絡(luò)。這類網(wǎng)絡(luò)的特點是:一、負(fù)載 能力特別強, 任何一個全局時鐘驅(qū)動線都可以驅(qū)動芯片內(nèi)部的觸發(fā)器; 二是時延差特別小; 三是時鐘信號波形畸變小, 工作可靠性好。因此, 在FPGA設(shè)計中最好的時鐘方案是: 由專用的全局時鐘輸入引腳驅(qū)動單個主時鐘去控制設(shè)計項目中的每一個觸發(fā)器。CPLD/FPGA都具有專門的全局時鐘引腳,它直接連到器件中的每一個寄存 器。這種全局時鐘提供器件中最短的時鐘到輸出的延時。同步設(shè)計時, 全局時鐘輸入一般都接在器件的時鐘端,
53、 否則會使其性能受到影響。對于需要多時鐘的時序電路, 最好選用一個頻率是它們的時鐘頻率公倍數(shù)的高頻主時鐘。 各個功能模塊要使用統(tǒng)一的復(fù)位電路。在使用帶時鐘的觸發(fā)器、計數(shù)器等有復(fù)位端的庫器件時, 一般應(yīng)盡量使用有同步復(fù)位的器件。注意復(fù)位時保證各個器件都能復(fù)位, 以避免某些寄存器的初始狀態(tài)不確定而引起系統(tǒng)工作不可靠。 時鐘設(shè)計過程中,不可缺少的要涉及到數(shù)據(jù)的建立時間和保持時間的概念,深刻理解這兩個概念有助于我們設(shè)計出優(yōu)良餓時鐘網(wǎng)絡(luò)。異步信號輸入總是無法滿 足數(shù)據(jù)的建立保持時間,所以建議大家把所有異步輸入都先經(jīng)過雙觸發(fā)器進(jìn)行同步化。在許多應(yīng)用中只將異步信號同步化還是
54、不夠的,當(dāng)系統(tǒng)中有兩個或兩個以上非 同源時鐘的時候,數(shù)據(jù)的建立和保持時間很難得到保證,我們將面臨復(fù)雜的時間問題,那么這個時候怎么辦呢?最好的方法是將所有非同源時鐘同步化,那么又怎么 樣將非同源時鐘同步化呢?我們可以使用帶使能端的D觸發(fā)器,并引入一個高頻時鐘(頻率高于系統(tǒng)中的所有源時鐘),便可以達(dá)到使系統(tǒng)中所有源時鐘同步的效 果。如下面的這個例子:系統(tǒng)有兩個不同源時鐘,一個為3MHz,一個為5MHz,不同的觸發(fā)器使用不同的時鐘。為了系統(tǒng)穩(wěn)定,假設(shè)我們引入一個20MHz時鐘,那么這個 20MHz的時鐘怎么才能將3M和5M時鐘同步化呢?20M的高頻時鐘將作為系統(tǒng)時鐘,輸入到所有觸發(fā)器的的時鐘端。3M
55、_EN 和5M_EN將控制所有觸發(fā)器的使能端。即原來接3M時鐘的觸發(fā)器,接20M時鐘,同時3M_EN 將控制該觸發(fā)器使能,原接5M時鐘的觸發(fā)器,也接20M時鐘,同時5M_EN 將控制該觸發(fā)器使能。這樣我們就可以將任何非同源時鐘同步化。在通常的FPGA設(shè)計中對時鐘偏差的控制主要有以下幾種方法:1、控制時鐘信號盡量走可編程器件的的全局時鐘網(wǎng)絡(luò)。在可編程器件中一般都有專門的時鐘驅(qū)動器及全局時鐘網(wǎng)絡(luò),不同種類、型號的可編程器件,它們中 的全局時鐘網(wǎng)絡(luò)數(shù)量不同,因此要根據(jù)不同的設(shè)計需要選擇含有合適數(shù)量全局時鐘網(wǎng)絡(luò)的可編程器件。一般來說,走全局時鐘網(wǎng)絡(luò)的時鐘信號到各使能端的延時小, 時鐘偏差很小,基本可以
56、忽略不計。2、若設(shè)計中時鐘信號數(shù)量很多,無法讓所有的信號都走全局時鐘網(wǎng)絡(luò),那么可以通過在設(shè)計中加約束的方法,控制不能走全局時鐘網(wǎng)絡(luò)的時鐘信號的時鐘偏 差。3、異步接口時序裕度要足夠大,局部同步電路之間接口都可以看成是異步接口,比較典型的是設(shè)計中的高低頻電路接口、I/O接口,那么接口電路中后一 級觸發(fā)器的建立-保持時間要滿足要求,時序裕度要足夠大。4、在系統(tǒng)時鐘大于30MHz時,設(shè)計難度有所加大,建議采用流水線等設(shè)計方法。5、要保證電路設(shè)計的理論最高工作頻率大于電路的實際工作頻率。復(fù)位和置位信號處理:在設(shè)計時應(yīng)盡量保證有一全局復(fù)位信號,或保證觸發(fā)器、計數(shù)器在使用前已經(jīng)正確清零狀態(tài)。在設(shè)計寄存器的
57、清除和置位信號時,應(yīng)盡量直接從器件的專用引 腳驅(qū)動。另外,要考慮到有些器件上電時,觸發(fā)器處于一種不確定的狀態(tài),系統(tǒng)設(shè)計時應(yīng)加入全局復(fù)位/Reset。這樣主復(fù)位引腳就可以給設(shè)計中的每一個觸發(fā)器饋送清除或置位信號,保證系統(tǒng)處于一個確定的初始狀態(tài)。需要注意的一點是:不要對寄存器的置位和清除端 同時施加不同信號產(chǎn)生的控制,因為如果出現(xiàn)兩個信號同時有效的意外情況,會使寄存器進(jìn)入不定狀態(tài)。3.zynq-7000板載資源賽靈思Zynq-7000 可擴展處理平臺(EPP)將雙 ARM Cortex-A9 MPCore 處理器系統(tǒng)與可編程邏輯和硬 IP 外設(shè)緊密集成在一起,提供了靈活性、可配置性和性能的完美組合
58、。圍繞其剛剛推出的可擴展處理平臺(EPP), 賽靈思在今年3月發(fā)布了基于Zynq -7000新系列的首批器件。 采用 28 nm制造工藝, Zynq-7000嵌入式處理平臺系列的每款產(chǎn)品均采用帶有NEON及雙精度浮點引擎的雙核 ARM Cortex-A9 MPCore 處理系統(tǒng),該系統(tǒng)通過硬連線完成了包括L1,L2 緩存、存儲器控制器以及常用外設(shè)在內(nèi)的全面集成。(圖 1)。盡管 FPGA 廠商此前已推出過帶硬核或軟核處理器的器件,但 Zynq-7000 EPP 的獨特之處在于它由ARM處理器系統(tǒng)而非可編程邏輯元件來進(jìn)行控制。也就是說,處理系統(tǒng)能夠在開機時引導(dǎo)(在 FPGA 邏輯之前)
59、并運行各個獨立于可編程邏輯之外的操作系統(tǒng)。這樣設(shè)計人員就可對處理系統(tǒng)進(jìn)行編程,根據(jù)需要來配置可編程邏輯。 利用這種方法,軟件編程模式將與全功能標(biāo)準(zhǔn) ARM 處理器片上系統(tǒng)(SoC)毫無二致。過去設(shè)計師需要對 FPGA 邏輯進(jìn)行編程以運行片上處理器。那就意味著如果想要使用器件,必須得是 FPGA 設(shè)計師。但現(xiàn)在使用 Zynq-7000 EPP,則完全不必?fù)?dān)心這一問題。 圖 1 不同于以往在 FPGA 架構(gòu)中嵌入 MPU ,賽靈思全新 Zynq-7000 EPP 系列使用 ARM 處理器而非可編程邏輯來進(jìn)行控制。圖1中文字:Multi Gigabit Transceivers 多個千兆位收發(fā)器 新產(chǎn)品系列消除了延遲和從頭設(shè)計芯片的風(fēng)險,這意味著系統(tǒng)設(shè)計團(tuán)隊可以利用其先進(jìn)的高級軟硬件編程多功能性簡便快速創(chuàng)建創(chuàng)新型片上系統(tǒng),而這是其他任何半導(dǎo)體器件都無法實現(xiàn)的。這樣,Zynq -7000 EPP 能夠為廣大的創(chuàng)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 山西省朔州市朔城區(qū)四中學(xué)2025年初三下學(xué)期期末質(zhì)量調(diào)查語文試題含解析
- 山東省菏澤市鄆城縣侯咽集鎮(zhèn)2024-2025學(xué)年數(shù)學(xué)四下期末質(zhì)量跟蹤監(jiān)視模擬試題含解析
- 響水縣2024-2025學(xué)年小升初總復(fù)習(xí)數(shù)學(xué)測試題含解析
- 內(nèi)蒙集寧二中2025屆高三下學(xué)期第三次調(diào)考英語試題含解析
- 山西省太原志達(dá)中學(xué)2025年初三第六次質(zhì)量檢測試題語文試題含解析
- 產(chǎn)品銷售代理合同協(xié)議書實例
- 房屋采購合同范本共
- 企業(yè)間租賃合同的優(yōu)異典范
- Brand KPIs for pet supply online shop Zen Animal in Brazil-外文版培訓(xùn)課件(2025.2)
- 小班藝術(shù)《魚眾不同》+教案
- 2022-2023學(xué)年山東省煙臺市高一(下)期中英語試卷-普通用卷
- 2023年高速鐵路隧道工程施工技術(shù)指南鐵建設(shè)【2023年】241號
- 中國民族史智慧樹知到答案章節(jié)測試2023年云南大學(xué)
- 德磐氫化丁腈橡膠
- 二手車購車合同范本2份(全國通用版)
- GB/T 33170.3-2016大型活動安全要求 第3部分:場地布局和安全導(dǎo)向標(biāo)識
- FZ/T 50004-2011滌綸短纖維干熱收縮率試驗方法
- 園林綠化工-中級-植物識別
- 7.2萬有引力定律說課課件(26張PPT)
- 中國人民大學(xué)自薦信模板
- 公共政策分析的基本理論與框架課件
評論
0/150
提交評論