www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 嵌入式 > 嵌入式教程
[導讀]基于EDA仿真技術解決FPGA設計開發(fā)中故障的方法

 FPGA近年來在越來越多的領域中應用,很多大通信系統(tǒng)(如通信基站等)都用其做核心數據的處理。但是過長的編譯時間,在研發(fā)過程中使得解決故障的環(huán)節(jié)非常令人頭痛。本文介紹的就是一種用仿真方法解決故障從而減少研發(fā)過程中的編譯次數,最終達到準確定位故障、縮短解決故障時間的目的。文例所用到的軟件開發(fā)平臺為Altera公司的Quartus II,仿真工具為ModelSim。

本文針對FPGA實際開發(fā)過程中,出現(xiàn)故障后定位困難、反復修改代碼編譯時間過長、上板后故障解決無法確認的問題,提出了一種采用仿真的方法來定位、解決故障并驗證故障解決方案??梢源蟠蟮墓?jié)約開發(fā)時間,提高開發(fā)效率。

  問題的提出

  系統(tǒng)開發(fā)在上板調試過程中,有時候出現(xiàn)的bug是很極端的情況或很少出現(xiàn)的情況,而現(xiàn)在通常的做法是:在故障出現(xiàn)的時候通過SignalTap 把信號抓出來查找其問題的所在、修改程序;在改完版本后,先要對整個工程進行重新編譯,然后再上板跑版本進行驗證,看看故障是否解決。

  這樣就會出現(xiàn)三個問題:

 ?、儆袝r候故障很難定位,只知道哪個模塊出錯,很難定位到具體的信號上,給抓信號帶來麻煩。如果故障定位不準確,漏抓了關鍵信號,則需要重新在 SignalTap里添加信號、編譯版本并再次上板定位故障,浪費時間。

 ?、诠收隙ㄎ缓?,修改代碼還需要再編譯一次產生新版本的下載文件,修改后若還有問題則要重復這一過程,這樣從故障定位到修改完成需要很多次編譯。

  ③上板重新進行驗證時,如果這個bug的出現(xiàn)的幾率很小,短時間內不再復現(xiàn),并不能說明在極端情況下的故障真的被解決了。

  舉例說明:

  例如在一個基帶系統(tǒng)的FPGA邏輯版本中,輸出模塊調用了一個異步FIFO,某一時刻FIFO已空的情況下多讀了一個數據,產生了bug,如圖 1所示。

圖1 SignalTap抓出的bug出現(xiàn)時的數據

  該輸出模塊的功能是判斷FIFO中是否有大于4個數據可讀出,若大于則連續(xù)輸出4個數據作為一組。系統(tǒng)中采用異步FIFO的內部讀數據指針來做判斷,而異步FIFO讀寫數據需要跨時鐘域,需要至少2個時鐘周期的握手時間,導致數據指針不準確。在判斷的時鐘沿,雖然顯示有超過4個的數據可讀,但是因為握手時間的延遲實際上FIFO中可能只有3個數據。

  圖1中rdreq為FIFO的讀使能信號,在4個時鐘周期內有效,但是只讀出了3個數(數據0D2086C9F被讀了兩次),因為FIFO在第 4個時鐘周期已經讀空。這里應該改成同步FIFO,由于同步FIFO數據的讀寫只在一個時鐘域內進行,就沒有這個握手時間延遲的問題了。

  定位這個故障的時候我們可以很容易知道是哪個模塊出了問題,但是具體是其內部的哪個信號還需要下些功夫,如果出錯信號隱藏的很深,很難一次就抓到需要的信號;而且即使我們抓到了正確的信號,如果故障在改完之后沒有解決,則還需要重新修改、再進行編譯,耗費時間;即使改過之后故障不再復現(xiàn),也有可能是因為bug出現(xiàn)的條件苛刻,無法證明故障真的解決了。

  針對這三個問題,筆者提出如下想法:

  雖然定位具體的出錯信號很困難,但是定位是哪個模塊出錯很容易,在bug出現(xiàn)的時候我們可以抓出這個模塊的全部輸入信號,考慮是否可以利用這些信號在仿真環(huán)境下重建bug出現(xiàn)的條件,利用仿真環(huán)境具體定位錯誤信號的位置。

  定位好錯誤信號的具體位置后,修改代碼,再用相同的條件進行仿真。這樣可以通過對修改前后輸出數據的對比,很直觀的驗證修改是否成功,從而在修改成功后只需編譯一次即可,節(jié)省時間。

  上板后bug不復現(xiàn)也可以排除是由于極端情況很難滿足造成的,去除了后顧之憂,徹底解決了故障。

  仿真解決故障的方法

  通過對這個異步FIFO問題的解決,可以證明這種通過所抓信號建立bug存在條件,定位、清除bug的方法是可行的。步驟如下:

  ①將bug出現(xiàn)時SignalTap抓的信號保存成文檔文件

  Quartus II 平臺用SignalTap抓到信號的界面如圖2所示。

圖2 SignalTap抓信號界面

  在信號名稱上單擊右鍵,選擇圖2所示Create SignalTap II List File選項,生成如圖3格式界面。

圖3 SignalTap II List File界面

  圖3中界面上半部分顯示的是list對信號個數及信號名的描述,下半部分是采樣點所對應的信號值,帶h的表示是十六進制數值。

  將list file另存為文本格式文件即可,如圖4所示。

[!--empirenews.page--]

圖4 “另存為”選項界面

 此后可以把這個文本文件中無用的描述刪掉,只留SignalTap抓出來的數據(空格、h等符號也要刪掉),另存為.dat文件供仿真使用。

  有了故障出現(xiàn)時的輸入數據,我們就可以在仿真環(huán)境下構建故障出現(xiàn)的條件。

 ?、诶?dat文件建立bug出現(xiàn)的條件

  用verilog語言編寫仿真文件(testbench),使用語句$readmemh或$readmemb將.dat文件中的數據存儲到一個設定的ram中,如:$readmemh(“s.dat”,ram)。

  注意$readmemh讀取是按照十六進制數據進行(認為.dat文件中的數據都是十六進制數),會自動將其轉換為4位二進制數存入ram中,所以設定的ram位寬要是.dat文件中數據位寬的4倍;使用$readmemb時,存儲SignalTap所抓信號時,信號都要先設定為binary類型,ram位寬就是.dat文件數據的位寬。ram的深度為.dat文件中數據的個數。

  然后在程序里把ram中數據按照所對應時鐘沿輸出到一個寄存器變量中,ram地址累加即可。

  always@(posedge clk)

  begin

  data<=ram[addr];

  addr<=addr+1‘b1;

  end

  復現(xiàn)bug存在條件時,需將模塊的輸入信號與ram中的數據位相對應,仿真文件調用模塊時,將寄存器data對應位作為輸入接入即可。

  在仿真環(huán)境中復現(xiàn)bug波形如圖5所示。

圖5 ModelSim環(huán)境下復現(xiàn)的出錯數據

  把圖5和圖1進行比較,可見通過這種方法我們在仿真環(huán)境下建立了bug出錯時的環(huán)境,得到相同的輸出出錯數據。

 ?、坌薷某绦蚝笤诜抡姝h(huán)境驗證修改是否成功

  修改程序后,我們只要使用同樣的環(huán)境進行仿真,并且有針對性的觀察bug是否解決。本例中出現(xiàn)bug的原因是使用了異步FIFO,改成同步 FIFO后,問題應該就會解決,我們可以通過仿真驗證。修改程序后仿真的波形如圖6所示。

圖6 修改程序后相同條件下的輸出數據

  由圖6可見,修改后相同的條件FIFO讀出4個數,說明沒有讀空,符合要求,bug解決。圖7為版本編譯后上板使用SignalTap抓取的信號波形,以作比較。

圖7 修改程序后SignalTap抓的信號

  比較后易見,波形完全相同,說明方法可行。

  總結

  文中描述的方法可針對各種的故障的解決。在故障出現(xiàn)時,只需定位出錯的模塊,這些模塊內嵌一些子模塊也無妨;抓信號時將故障模塊的輸入輸出信號抓出即可;利用輸入信號重建故障環(huán)境,若仿真輸出信號和所抓輸出信號相同,說明故障環(huán)境建立正確;用這個仿真平臺就可以具體定位是哪個子模塊、哪個信號出錯,而不需要在SignalTap中把這些信號抓出來;并且在修改代碼后可以驗證是否修改成功,節(jié)省時間,很明確的證明故障真的被解決了,事半功倍。

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: 驅動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設備,其驅動電源的性能直接關系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅動電源設計中至關重要的兩個環(huán)節(jié),集成化方案的設計成為提升電機驅動性能的關鍵。

關鍵字: 工業(yè)電機 驅動電源

LED 驅動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設備的使用壽命。然而,在實際應用中,LED 驅動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設計、生...

關鍵字: 驅動電源 照明系統(tǒng) 散熱

根據LED驅動電源的公式,電感內電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關鍵字: LED 設計 驅動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產業(yè)的重要發(fā)展方向。電動汽車的核心技術之一是電機驅動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅動系統(tǒng)中的關鍵元件,其性能直接影響到電動汽車的動力性能和...

關鍵字: 電動汽車 新能源 驅動電源

在現(xiàn)代城市建設中,街道及停車場照明作為基礎設施的重要組成部分,其質量和效率直接關系到城市的公共安全、居民生活質量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關鍵字: 發(fā)光二極管 驅動電源 LED

LED通用照明設計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數校正(PFC)、空間受限和可靠性等。

關鍵字: LED 驅動電源 功率因數校正

在LED照明技術日益普及的今天,LED驅動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關鍵字: LED照明技術 電磁干擾 驅動電源

開關電源具有效率高的特性,而且開關電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅動電源

關鍵字: LED 驅動電源 開關電源

LED驅動電源是把電源供應轉換為特定的電壓電流以驅動LED發(fā)光的電壓轉換器,通常情況下:LED驅動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: LED 隧道燈 驅動電源
關閉