大家好,又到了每日學習的時候了。自1985年問世以來,FPGA這種可編程邏輯器件憑借在性能、上市時間、成本、穩定性和長期維護方面的優勢,在通信、醫療、工控和安防等領域占有一席之地。特別是近兩年,隨著云計算、高性能計算和人工智能的繁榮,擁有先天優勢的FPGA更是得到了前所未有的關注。近幾年隨著國家開始大力發展實業,國內集成電路行業發展越來越好,隨之由于用戶對性能的要求越來越高,FPGA的可編程、高速度、低功耗、較低的二次開發成本的優越特性,帶動了FPGA行業的發展,有很多同學們開始自學FPGA。
首先,先來了解一下FPGA,FPGA:Field-Programmable Gate Array,中文名字:現場可編程門陣列。FPGA由六部分組成:可編程輸入/輸出單元、基本可編程邏輯單元、嵌入式塊RAM、豐富的布線資源、底層嵌入功能單元和內嵌專用硬核。英特爾首席執行官科再奇曾這樣描述:“你可以把FPGA想象成一堆gate,能夠隨時編程。FPGA可以用作多個領域的加速器,例如在加密的同時進行面部搜索,并能在微秒內重新編程。其成本遠低于大規模單個定制部件,并具有更高的靈活性。”
FPGA是可編程器件,與傳統邏輯電路和門陣列(如PAL,GAL及CPLD器件)相比,具有不同的結構,FPGA利用小型查找表(16×1RAM)來實現組合邏輯,每個查找表連接到一個D觸發器的輸入端,觸發器再來驅動其他邏輯電路或驅動I/O,由此構成了既可實現組合邏輯功能又可實現時序邏輯功能的基本邏輯單元模塊,這些模塊間利用金屬連線互相連接或連接到I/O模塊。FPGA的邏輯是通過向內部靜態存儲單元加載編程數據來實現的,存儲在存儲器單元中的值決定了邏輯單元的邏輯功能以及各模塊之間或模塊與I/O間的聯接方式,并最終決定了FPGA所能實現的功能,FPGA允許無限次的編程。
下圖為四輸入查找表結構。
下圖為FPGA的結構
關于FPGA概念以及結構等等的介紹就到這里,如果大家還想要詳細了解,可以自己去查閱資料。接下來,咱們就來聊聊初學FPGA時需要注意哪些知識點或者小細節,希望對大家的學習有所幫助。 區別一下軟硬件幾種類型
通用應用軟件
a. 軟件匯編語言(Assembly Language)是面向機器的程序設計語言。
b. 主要關心邏輯和抽象,關心代碼量大了之后復雜度可控。硬件資源較多,硬件性能差別較大,不需要針對特定資源設計。
c. 邏輯分層較多,來源于抽象的性能損耗可以接受。甚至于現在很多主流語言構建在虛擬機和解釋器上。
d. 非實時。
e. 不需要了解底層硬件原理。
嵌入式軟件(面向硬件編程)
a. 時序可控。大部分場景要求實時,因為要滿足硬件時序。非搶占的任務調度和中斷隊列都會引入定時的偏差。
b. 資源開銷可控。因為嵌入式硬件環境大多只有有限的 RAM 和 Flash 資源。
c. 針對特定硬件環境設計。
d. 所有代碼上的抽象和優化都必須是零損耗或者損耗可控(可以參考 rust 語言)。比較典型的是 GC 會引入嚴重的時序和資源不可控,所以系統語言很少使用。
數字邏輯電路設計(硬件描述性語言)
a. 數字電路設計不是編程,是設計的時候先有電路,再用語言描述出來。
b. 時序要求更嚴,需要考慮建立時間和保持時間,及隨之而來的亞穩態。
c. Coding style 會明顯的影響電路性能。邏輯都一樣,但是 DFF 的位置不一樣,就可能導致時序不滿足。
d. 并行化。執行順序不再是 CPU 的順序執行,而是多個并行的流水線。比如快速傅立葉 FFT。比如路由器的 CAM,單次動作完成整表查表。
1. FPGA學習時使用的 VHDL 和 verilog HDL 不是編程語言,而是一種可綜合的硬件描述語言,我們在描述的時候一定要明白所要設計的是一個怎樣的電路。
2. 當今社會做開發用的 Verilog HDL 語言偏多,Verilog HDL 支持兩種進程 initial 和 always 進程,前者只能用在TB(TestBench)中,后者才是可綜合的。
3. 阻塞與非阻塞指都是相對于進程本身而言的,簡單來講,阻塞用在描述組合邏輯電路,而非阻塞用于時序邏輯電路。
4. 使用進程模塊的電路類型:
組合電路-----對組合邏輯中使用的所有輸入敏感
例子:
always@(a or b or c)
時序電路-----僅對時鐘和控制信號敏感
例子:
always @(posedge clk or negedge rst_n)
always既可以描述組合邏輯,也可以描述時序邏輯。
5. 可以用case語句完成多路選擇器的功能,但是列舉的情況一定要考慮全,否則會產生Latch。
6. verilog中有兩類子程序:
函數和任務
函數-----根據輸入返回一個值
-----產生組合邏輯
-----用在表達式中:assign mult_out=mult(ina,inb);
-----函數是組合邏輯,不能含有任何延時,事件,或者時序控制聲明,至少有一個輸入變量
總是返回一個變量
-----可以調用函數,但是不能調用任務。
任務-----可以是組合或者寄存器
-----以聲明的形式調用任務:stm_out(nxt,first,sel,filter);
-----與其他編程語言中的任務相似
-----與函數不同任務不需要傳遞參數,而函數要傳遞參數
-----可以調用任務和函數。
----- 可以含有任何延時,事件,或者時序控制聲明
-----返回零個或者多個數值
可綜合的verilog語法子集是指用硬件可以實現的語法。力求用最簡單的語言實現最復雜的硬件電路。
7. 硬件都有相應的輸入輸出的接口,或者是輸入或者是輸出,或者是輸入輸出。
8. reg 型是指時序邏輯里面的一個寄存數據(寄存機類型),wire 是組合邏輯里面的一條連線(線型)。
9. define 定義了一個參數,在整個工程里面都是有效地使用。parameter 定義的一個參數只在當前文件里面進行使用。
10. 各種邏輯操作符,移位操作符,算術操作符大多是可綜合的。
11. assign一般是只針對于組合邏輯,而always語句既可以用于組合邏輯又可以用于時序邏輯,always模塊的敏感表,如果是電平,則為組合邏輯,如果是沿信號posedge或者negedge 則為時序邏輯。
12. begin----end和C語言里面的{}是類似的。
13. for 語句-----循環因為綜合出來的結果可能比較浪費資源,所以就一般用的比較少,但是在一些特定的設計中可以起到事半功倍的效果。
14. Total logic element 總共消耗的邏輯單元。
15. 行為級仿真可以理解為功能仿真(前仿真);布局布線后仿真可以理解為時序仿真(后仿真)。
16. 時序邏輯中時鐘和復位信號是必須的。
17. 注意wire賦值的一個問題如下:
wire[2:0] key_an=key_rst_r&(~key_rst)
其相當于如下的一個賦值語句
wire[2:0] key_an;
assign key_an=key_rst_r&(~key_rst);
其實現的效果是一樣的。
此種方法為:脈沖邊沿檢測法。
18. 實際工作中,除了描述仿真測試激勵(Testbench)時使用for循環語句外,極少在RTL級編碼中使用for循環,這是因為for循環會被綜合器展開為所有變量情況的執行語句,每個變量獨立占用寄存器資源,不能有效的復用硬件邏輯資源,造成巨大的浪費。一般常用case語句代替。
19. FPGA一般觸發器資源比較豐富,而CPLD組合邏輯資源更豐富。
20. FPGA使用的兩種語言:VHDL 和 verilog HDL 。
VHDL 為美國國防部發明,用于較多的設計人員合作完成的特大型項目(一百萬門以上),語法/結構比較嚴謹,因為編寫出的模塊風格清晰。
verilog HDL 第三方支持工具較多,語法結構比VHDL簡單,學習來比較容易,仿真工具比較好用,測試激勵模塊容易編寫。
21. 時序設計的實質:電路設計的難點在于時序設計,實質就是滿足么一個觸發器 建立時間/保持時間 的要求。
(備注:建立時間:觸發器在時鐘上升沿到來之前,其數據輸入端的數據必須保持不變的最小時間;保持時間:觸發器在時鐘上升沿到來之后,觸發器在時鐘上升沿到來之前,其數據輸入端的數據必須保持不變的最小時間。)
22. 為什么觸發器要滿足建立時間和保持時間?
因為觸發器內部數據的形成是需要一定的時間的,如果不滿足建立和保持時間,觸發器將進入亞穩態,進入亞穩態后觸發器的輸出將不穩定,在0和1之間變化,這時需要經過一個恢復時間,其輸出才能 穩定,但穩定后的值并不一定是你的輸入值。這就是為什么要用兩級觸發器來同步異步輸入信號。這樣做可以防止由于異步輸入信號對于本級時鐘可能不滿足建立保持時間而使本級觸發器產生的亞穩態傳播到后面邏輯中,導致亞穩態的傳播。
23. 鎖存器(latch)和觸發器(flip-flop)區別?
電平敏感的存儲器件稱為鎖存器。可分為高電平鎖存器和低電平鎖存器,用于不同時鐘之間的信號同步。
有交叉耦合的門構成的雙穩態的存儲原件稱為觸發器。分為上升沿觸發和下降沿觸發。可以認為是兩個不同電平敏感的鎖存器串連而成。前一個鎖存器決定了觸發器的建立時間,后一個鎖存器則決定了保持時間。
24. and so on.
最后,我們來簡單聊一聊FPGA的應用范圍。FPAG的應用越來越廣泛,航天航空、汽車駕駛、醫療、廣播、測量測試、消費電子、工業控制、計算機設備、武器裝備等等。從應用場景角度分析,我們可以看到隨著谷歌的阿爾法狗打敗了人類圍棋冠軍后,深度學習已經從神壇走下來,越來越多的人開始認識到深度學習可能會改變未來的生活,成為未來科技發展的方向;而FPGA設計工具使其對深度學習領域經常使用的上層軟件兼容性更強,FPGA正是助力深度學習的一大技術。不同于CPU的是,FPGA和GPU內都有大量的計算單元,因此它們的計算能力都很強。在進行神經網絡運算的時候,兩者的速度會比CPU快很多。但是GPU由于架構固定硬件原生支持的指令固定了,而FPGA則是可編程的。
隨著國家綜合實力越來越強大,國民經濟越來越好,FPGA從之前的運用廣泛的軍工行業在慢慢延伸到民用行業,并且會越來越廣泛。
原文標題:FPGA學習需要注意的知識點
文章出處:【微信公眾號:FPGA設計論壇】歡迎添加關注!文章轉載請注明出處。
責任編輯:haq
-
FPGA
+關注
關注
1630文章
21777瀏覽量
604760
原文標題:FPGA學習需要注意的知識點
文章出處:【微信號:gh_9d70b445f494,微信公眾號:FPGA設計論壇】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論