国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

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

3天內不再提示

FPGA設計的八個技術技巧

FPGA研究院 ? 來源:FPGA研究院 ? 作者:FPGA研究院 ? 2022-11-15 09:38 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1. 面積與速度的平衡與互換

這里的面積指一個設計消耗FPGA/CPLD的邏輯資源的數量,對于FPGA可以用消耗的FF(觸發器)和LUT(查找表)來衡量,更一般的衡量方式可以用設計所占的等價邏輯門數。 速度指設計在芯片上穩定運行所能達到的最高頻率,這個頻率由設計的時序狀況來決定,以及設計滿足的時鐘要求:PAD to PAD time 、Clock Setup Time、Clock Hold Time、Clock-to-Output Delay等眾多時序特征量密切相關。 面積和速度這兩個指標貫穿FPGA/CPLD設計的時鐘,是設計質量的評價的終極標準 ——面積和速度是一對對立統一的矛盾體。 要求一個同時具備設計面積最小、運行頻率最高是不現實的。更科學的設計目標應該是在滿足設計時序要求(包括對設計頻率的要求)的前提下,占用最小的芯片面積。或者在所規定的面積下,是設計的時序余量更大、頻率跑的更高。這兩種目標充分體現了面積和速度的平衡的思想。 作為矛盾的兩個組成部分,面積和速度的地位是不一樣的。相比之下,滿足時序、工作頻率的要求更重要一些,當兩者沖突時,采用速度優先的準則。 從理論上講,如果一個設計時序余量較大,所能跑的速度遠遠高于設計要求,那么就通過功能模塊的復用來減少整個設計消耗的芯片面積,這就是用速度的優勢換取面積的節約。反之,如果一個設計的時序要求很高,普通方法達不到設計頻率,那么一般可以通過將數據流串并轉換,并行復制多個操作模塊,對整個設計采取乒乓操作和串并轉換的思想運行。

2.硬件原則

硬件原則主要針對HDL代碼編寫而言:Verilog是采用了C語言形式的硬件的抽象,它的本質作用在于描述硬件,它的最終實現結果是芯片內部的實際電路。所以評判一段HDL代碼的優劣的最終標準是:其描述并實現的硬件電路的性能,包括面積和速度兩個方面。 評價一個設計的代碼水平較高,僅僅是說這個設計是由硬件想HDL代碼這種表現形式的轉換更加流暢、合理。而一個設計最終性能,在更大程度上取決于設計工程師所構想的硬件實現方案的效率以及合理性。(HDL代碼僅僅是硬件設計的表達形式之一) 初學者片面追求代碼的整潔、簡短,是錯誤的,是與HDL的標準背道而馳的。正確的編碼方法,首先要做到對所需實現的硬件電路胸有成竹,對該部分的硬件的結構和連接十分清晰,然后再用適當的HDL語句表達出來即可。 另外,Verilog作為一種HDL語言,是分層次的。系統級--算法級--寄存器傳輸級--邏輯級--門級--開關級。構建優先級樹會消耗大量的組合邏輯,所以如果能夠使用case的地方,盡量使用case代替if.....else......

3. 系統原則

系統原則包含兩個層次的含義:更高層面上看,是一個硬件系統,一塊單板如何進行模塊花費和任務分配,什么樣的算法和功能適合放在FPGA里面實現,什么樣的算法和功能適合放在DSP/CPU里面實現,以及FPGA的規模估算數據接口設計等。具體到FPGA設計就要對設計的全局有個宏觀上的合理安排,比如時鐘域、模塊復用、約束、面積、速度等問題,在系統上模塊的優化最為重要。 一般來說實時性要求高,頻率快的功能模塊適合FPGA實現。而FPGA和CPLD相比,更適合實現規模較大、頻率較高、寄存器較多的設計。使用FPGA/CPLD設計時,應該對芯片內部的各種底層硬件資源,和可用的設計資源有一個較深刻的認識。 比如FPGA一般觸發器資源豐富,CPLD的組合邏輯資源更加豐富。FPGA/CPLD一般是由底層可編程硬件單元、BRAM、布線資源、可配置IO單元、時鐘資源等構成。 底層可編程硬件單元一般由觸發器和查找表組成。Xilinx的底層可編程硬件資源較SLICE,由兩個FF和2個LUT構成。Altera的底層硬件資源叫LE,由1個FF和1個LUT構成。使用片內RAN可以實現單口RAM、雙口RAM、同步/異步FIFO、ROM、CAM等常用單元模塊。

a05d1cf0-6479-11ed-8abf-dac502259ad0.png

一般的FPGA系統規劃的簡化流程

4. 同步設計原則

異步電路的邏輯核心是用組合邏輯電路實現,比如異步的FIFO/RAM讀寫信號,地址譯碼等電路。電路的主要信號、輸出信號等并不依賴于任何一個時鐘性信號,不是由時鐘信號驅動FF產生的。異步時序電路的最大缺點是容易產生毛刺,在布局布線后仿真和用邏輯分析儀觀測實際信號時,這種毛刺尤其明顯。 同步時序電路的核心邏輯用各種各樣的觸發器實現,電路的主要信號、輸出信號都是由某個時鐘沿驅動觸發器產生出來的。同步時序電路可以很好的避免毛刺,布局布線后仿真,和用邏輯分析儀采樣實際工作信號都沒有毛刺。

是否時序電路一定比異步電路使用更多的資源呢?從單純的ASCI設計來看,大約需要7個門來實現一個D觸發器,而一個門即可實現一個2輸入與非門,所以一般來說,同步時序電路比異步電路占用更大的面積。(FPGA/CPLD中不同,主要是因為單元塊的計算方式)

如何實現同步時序電路的延時?異步電路產生延時的一般方法是插入一個Buffer、兩級與非門等,這種延時調整手段是不適用同步時序設計思想的。首先要明確一點HDL語法中的延時控制語法,是行為級的代碼描述,常用于仿真測試激勵,但是在電路綜合是會被忽略,并不能啟動延時作用。

同步時序電路的延時一般是通過時序控制完成的,換句話說,同步時序電路的延時被當做一個電路邏輯來設計。對于比較大的和特殊定時要求的延時,一般用高速時鐘產生一個計數器,通過計數器的計數控制延遲;對于比較小的延時,可以用D觸發器打一下,這種做法不僅僅使信號延時了一個時鐘周期,而且完成了信號與時鐘的初次同步,在輸入信號采樣和增加時序約束余量中使用。

同步時序電路的時鐘如何產生?時鐘的質量和穩定性直接決定著同步時序電路的性能。輸入信號的同步時序電路要求對輸入信號進行同步化,如果輸入數據的節拍和本級芯片的處理時鐘同頻,并且建立保持時間匹配,可以直接用本級芯片的主時鐘對輸入數據寄存器采樣,完成輸入數據的同步化。如果輸入數據和本級芯片的處理時鐘是異步的,特別是頻率不匹配的時候,則要用處理時鐘對輸入數據做兩次寄存器采樣,才能完成輸入數據的同步化。

是不是定義為Reg型,就一定綜合成寄存器,并且是同步時序電路呢?答案的否定的。Verilog中最常用的兩種數據類型Wire和Reg,一般來說,Wire型指定書數據和網線通過組合邏輯實現,而reg型指定的數據不一定就是用寄存器實現。

5. 乒乓操作

“ 乒乓操作 ” 是一個常常應用于數據流控制的處理技巧,乒乓操作的處理流程為:輸入數據流通過 “ 輸入數據選擇單元 ” 將數據流等時分配到兩個數據緩沖區,數據緩沖模塊可以為任何存儲模塊,比較常用的存儲單元為雙口 RAM(DPRAM) 、單口 RAM(SPRAM) 、 FIFO 等。

在第一個緩沖周期,將輸入的數據流緩存到 “ 數據緩沖模塊 1” ;在第 2 個緩沖周期,通過 “ 輸入數據選擇單元 ” 的切換,將輸入的數據流緩存到 “ 數據緩沖模塊 2” ,同時將 “ 數據緩沖模塊 1” 緩存的第 1 個周期數據通過 “ 輸入數據選擇單元 ” 的選擇,送到 “ 數據流運算處理模塊 ” 進行運算處理;在第 3 個緩沖周期通過 “ 輸入數據選擇單元 ” 的再次切換,將輸入的數據流緩存到 “ 數據緩沖模塊 1” ,同時將 “ 數據緩沖模塊 2” 緩存的第 2 個周期的數據通過 “ 輸入數據選擇單元 ” 切換,送到 “ 數據流運算處理模塊 ” 進行運算處理。如此循環。

a07b5ea4-6479-11ed-8abf-dac502259ad0.jpg

典型的乒乓操作方法 乒乓操作的最大特點是,通過輸入數據選擇單元和輸出數據選擇單元、進行運算和處理。把乒乓操作模塊當成一個整體,站在兩端看數據,輸入數據和輸出數據流都是連續不斷的,沒有任何停頓,因此非常適合對數據流進行流水線式處理。所以乒乓操作常常應用于流水線式算法,完成數據的無縫緩沖和處理。 乒乓操作的第二個優點是可以節約緩沖區空間。比如在WCDMA基帶應用中,1幀是由15個時隙組成的,有時需要將1整幀的數據延時一個時隙后處理,比較直接的方法就是將這幀數據緩存起來,然后延時一個時隙,進行處理。這時緩沖區的長度為1幀的數據長,假設數據速率是3.84Mb/s,1幀10ms,此時需要緩沖區的長度是38400bit,如果采用乒乓操作,只需定義兩個緩沖1時隙的數據RAM,當向一個RAM寫數據時,從另一塊RAM讀數據,然后送到處理單元處理,此時每塊RAM的容量僅需2560bit,2塊加起來5120bit的容量。

a087e5b6-6479-11ed-8abf-dac502259ad0.jpg

乒乓操作用低速模塊處理高速數據流

另外,巧妙運用乒乓操作還可以達到用低速模塊處理高速數據流的效果。如圖 2 所示,數據緩沖模塊采用了雙口 RAM ,并在 DPRAM 后引入了一級數據預處理模塊,這個數據預處理可以根據需要的各種數據運算,比如在 WCDMA 設計中,對輸入數據流的解擴、解擾、去旋轉等。假設端口 A 的輸入數據流的速率為 100Mbps ,乒乓操作的緩沖周期是 10ms 。

6. 串并轉換設計技巧

串并轉換是 FPGA 設計的一個重要技巧,它是數據流處理的常用手段,也是面積與速度互換思想的直接體現。串并轉換的實現方法多種多樣,根據數據的排序和數量的要求,可以選用寄存器、 RAM 等實現。 前面在乒乓操作的圖例中,就是通過 DPRAM 實現了數據流的串并轉換,而且由于使用了 DPRAM ,數據的緩沖區可以開得很大,對于數量比較小的設計可以采用寄存器完成串并轉換。如無特殊需求,應該用同步時序設計完成串并之間的轉換。比如數據從串行到并行,數據排列順序是高位在前,可以用下面的編碼實現:prl_temp<={prl_temp,srl_in}。 ? 其中, prl_temp 是并行輸出緩存寄存器, srl_in 是串行數據輸入。對于排列順序有規定的串并轉換,可以用 case 語句判斷實現。對于復雜的串并轉換,還可以用狀態機實現。串并轉換的方法比較簡單,在此不必贅述。

7.流水線操作設計思想

首先需要聲明的是,這里所講述的流水線是指一種處理流程和順序操作的設計思想,并非 FPGA 、 ASIC 設計中優化時序所用的 “Pipelining” 。 流水線處理是高速設計中的一個常用設計手段。如果某個設計的處理流程分為若干步驟,而且整個數據處理是 “ 單流向 ” 的,即沒有反饋或者迭代運算,前一個步驟的輸出是下一個步驟的輸入,則可以考慮采用流水線設計方法來提高系統的工作頻率。

a09c30c0-6479-11ed-8abf-dac502259ad0.jpg

流水線設計的結構 流水線設計的結構示意圖如圖所示。其基本結構為:將適當劃分的 n 個操作步驟單流向串聯起來。流水線操作的最大特點和要求是,數據流在各個步驟的處理從時間上看是連續的,如果將每個操作步驟簡化假設為通過一個 D 觸發器 ( 就是用寄存器打一個節拍 ) ,那么流水線操作就類似一個移位寄存器組,數據流依次流經 D 觸發器,完成每個步驟的操作。

a0b52990-6479-11ed-8abf-dac502259ad0.jpg

流水線設計時序 流水線設計的一個關鍵在于整個設計時序的合理安排,要求每個操作步驟的劃分合理。如果前級操作時間恰好等于后級的操作時間,設計最為簡單,前級的輸出直接匯入后級的輸入即可;如果前級操作時間大于后級的操作時間,則需要對前級的輸出數據適當緩存才能匯入到后級輸入端;如果前級操作時間恰好小于后級的操作時間,則必須通過復制邏輯,將數據流分流,或者在前級對數據采用存儲、后處理方式,否則會造成后級數據溢出。 在 WCDMA 設計中經常使用到流水線處理的方法,如 RAKE 接收機、搜索器、前導捕獲等。流水線處理方式之所以頻率較高,是因為復制了處理模塊,它是面積換取速度思想的又一種具體體現。

8. 數據接口的同步方法

數據接口的同步是 FPGA/CPLD 設計的一個常見問題,也是一個重點和難點,很多設計不穩定都是源于數據接口的同步有問題。在電路圖設計階段,一些工程師手工加入 BUFT 或者非門調整數據延遲,從而保證本級模塊的時鐘對上級模塊數據的建立、保持時間要求。 還有一些工程師為了有穩定的采樣,生成了很多相差 90 度的時鐘信號,時而用正沿打一下數據,時而用負沿打一下數據,用以調整數據的采樣位置。這兩種做法都十分不可取,因為一旦芯片更新換代或者移植到其它芯片 組的芯片上,采樣實現必須重新設計。而且,這兩種做法造成電路實現的余量不夠,一旦外界條件變換 ( 比如溫度升高 ) ,采樣時序就有可能完全紊亂,造成電路癱瘓。

輸入、輸出的延時 ( 芯片間、 PCB 布線、一些驅動接口元件的延時等 ) 不可測,或者有可能變動的條件下,如何完成數據同步?對于數據的延遲不可測或變動,就需要建立同步機制,可以用一個同步使能或同步指示信號。另外,使數據通過 RAM 或者 FIFO 的存取,也可以達到數據同步目的。

設計數據接口同步是否需要添加約束?建議最好添加適當的約束,特別是對于高速設計,一定要對周期、建立、保持時間等添加相應的約束。這里附加約束的作用有兩點:提高設計的工作頻率,滿足接口數據同步要求;獲得正確的時序分析報告。

審核編輯:郭婷

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • FPGA
    +關注

    關注

    1660

    文章

    22412

    瀏覽量

    636282
  • cpld
    +關注

    關注

    32

    文章

    1259

    瀏覽量

    173890
  • 觸發器
    +關注

    關注

    14

    文章

    2056

    瀏覽量

    63400

原文標題:干貨|FPGA設計的八個重要知識點,你都會嗎?

文章出處:【微信號:FPGA研究院,微信公眾號:FPGA研究院】歡迎添加關注!文章轉載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    大常見芯片封裝類型及應用!

    八個常見芯片封裝類型在芯片封裝就像半導體的“保護殼”,不僅能保護芯片核心,還直接決定芯片適配哪些產品、發揮多少性能。不管是日常用的手機、電腦,還是工業設備里的芯片,都離不開合適的封裝。今天就用通俗
    的頭像 發表于 02-02 15:01 ?573次閱讀
    <b class='flag-5'>八</b>大常見芯片封裝類型及應用!

    AFE5801 通道 12 位 65MSPS 模擬前端(AFE)產品手冊總結

    AFE5801是模擬前端,面向性能和集成水平至關重要的應用。該器件包含八個可變增益放大器(VGA),每個放大器后面跟一高速(最高65MSPS)ADC,每件設備共計八個ADC。 八個
    的頭像 發表于 11-24 10:05 ?603次閱讀
    AFE5801 <b class='flag-5'>八</b>通道 12 位 65MSPS 模擬前端(AFE)產品手冊總結

    AFE8092 8 發射、8 接收 RF 采樣收發器技術手冊

    AFE8092是一款高性能、寬帶寬的多通道收發器,集成了八個射頻采樣發射器鏈、八個射頻采樣接收器鏈和兩獨立的射頻前端,用于輔助鏈(反饋路徑)。發射機和接收機鏈的高動態范圍允許為無線基站生成和接收 3G、4G 和 5G 信號,A
    的頭像 發表于 10-31 14:49 ?702次閱讀
    AFE8092 8 <b class='flag-5'>個</b>發射、8 <b class='flag-5'>個</b>接收 RF 采樣收發器<b class='flag-5'>技術</b>手冊

    AFE8030 技術文檔總結

    AFE8030是一款高性能、寬帶寬的多通道收發器,集成了八個射頻采樣發射器鏈、八個射頻采樣接收器鏈和兩獨立的射頻前端,用于輔助鏈(反饋路徑)。發射器和接收器鏈的高動態范圍允許為無線基站生成和接收 3G、4G 和 5G 信號,A
    的頭像 發表于 10-30 15:10 ?638次閱讀
    AFE8030 <b class='flag-5'>技術</b>文檔總結

    AFE20408 8 通道功率放大器監控與控制器技術文檔總結

    該AFE20408是一種高度集成的功率放大器(PA)監控和控制設備,能夠進行溫度、電流和電壓監控。 AFE20408偏置控制器基于八個具有可編程輸出范圍的數模轉換器(DAC)。八個柵極偏置輸出
    的頭像 發表于 10-24 18:22 ?1524次閱讀
    AFE20408 8 通道功率放大器監控與控制器<b class='flag-5'>技術</b>文檔總結

    AMC7908 通道功率放大器監測與控制器技術文檔總結

    該AMC7908是一種高度集成的功率放大器(PA)監控和控制設備,能夠進行溫度、電流和電壓監控。 AMC7908偏置控制器基于八個具有可編程輸出范圍的數模轉換器(DAC)。八個柵極偏置輸出通過
    的頭像 發表于 10-24 11:31 ?713次閱讀
    AMC7908 <b class='flag-5'>八</b>通道功率放大器監測與控制器<b class='flag-5'>技術</b>文檔總結

    ?SN74LV8T374 路D型觸發器技術文檔總結

    SN74LV8T374包含八個 D 型人字拖。所有通道共享上升沿觸發時鐘 (CLK) 輸入和低電平有效輸出使能 (OE) 輸入。該器件具有流通引腳排列,可以更輕松地進行總線布線。
    的頭像 發表于 09-28 14:01 ?1105次閱讀
    ?SN74LV8T374 <b class='flag-5'>八</b>路D型觸發器<b class='flag-5'>技術</b>文檔總結

    ?SN74LV8T273 路D型觸發器技術文檔總結

    該SN74LV8T273包含八個正邊沿觸發的D型觸發器,具有直接的低電平有效清除(CLR)輸入。 滿足建立時間要求的數據 (D) 輸入端的信息傳輸到時鐘 (CLK) 脈沖正向沿的 Q 輸出
    的頭像 發表于 09-28 10:30 ?939次閱讀
    ?SN74LV8T273 <b class='flag-5'>八</b>路D型觸發器<b class='flag-5'>技術</b>文檔總結

    Texas Instruments CDCDB803用于PCIe?第1代至第5代的8輸出時鐘緩沖器數據手冊

    、QuickPath互連 (QPI)、UPI、SAS和SATA接口分配參考時鐘。其SMBus接口和八個輸出使能引腳可實現所有八個輸出的單獨配置和控制。
    的頭像 發表于 09-26 15:14 ?746次閱讀
    Texas Instruments CDCDB803用于PCIe?第1代至第5代的8輸出時鐘緩沖器數據手冊

    SN74HCS541 Octal Buffers and Line Drivers技術解析

    Texas Instruments SN74HCS541/SN74HCS541-Q1路緩沖器和線路驅動器包含八個緩沖器,具有三態輸出和施密特觸發輸入。Texas Instruments
    的頭像 發表于 09-24 09:48 ?755次閱讀
    SN74HCS541 Octal Buffers and Line Drivers<b class='flag-5'>技術</b>解析

    AFE8092通道RF收發器技術解析與應用指南

    Texas Instruments AFE8092通道RF收發器是一款高性能、高帶寬、多通道收發器,集成了八個RF采樣發送器鏈、八個RF采樣接收器鏈和兩用于輔助鏈(反饋路徑)的獨立
    的頭像 發表于 09-12 14:16 ?888次閱讀

    2025紫光同創FPGA技術研討會武漢站和北京站圓滿收官

    盛夏月,全力以赴,紫光同創FPGA技術研討會先后走入武漢、北京兩座科技創新城市,吸引了來自通信、工業控制、醫療、圖像視頻、消費電子等領域近200位專業觀眾,共同交流和探索FPGA
    的頭像 發表于 08-18 15:05 ?4207次閱讀

    Texas Instruments SN74LV8T541-EP通道緩沖器和線路驅動器數據手冊

    Texas Instruments SN74LV8T541-EP路緩沖器/線路驅動器包含八個具有3態輸出的緩沖器。低電平有效輸出能夠使引腳(OE1和OE2)配置為使輸出都必須為低電平才能有效,并
    的頭像 發表于 07-05 10:15 ?775次閱讀
    Texas Instruments SN74LV8T541-EP<b class='flag-5'>八</b>通道緩沖器和線路驅動器數據手冊

    Analog Devices / Maxim Integrated MAX22199進制工業數字輸入特性/應用/框圖

    Analog Devices MAX22199通道工業數字輸入將八個24V吸收電流的工業輸入轉換為對接3V至5.5V邏輯且兼容SPI的串行輸出。符合IEC 61131-2標準的工業數字輸入器件可用
    的頭像 發表于 06-25 15:37 ?735次閱讀
    Analog Devices / Maxim Integrated MAX22199<b class='flag-5'>八</b>進制工業數字輸入特性/應用/框圖

    ADMV4928 37.0 GHz至43.5 GHz發射/接收雙極化波束形成器技術手冊

    ADMV4928是一款絕緣體上硅(SOI)、37.0 GHz至43.5 GHz、mmW 5G波束形成器。RF集成電路(RFIC)高度集成,包含16獨立的發射和接收通道。ADMV4928通過獨立的RFV和RFH輸入/輸出支持八個水平和
    的頭像 發表于 04-08 17:41 ?1157次閱讀
    ADMV4928 37.0 GHz至43.5 GHz發射/接收雙極化波束形成器<b class='flag-5'>技術</b>手冊