日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 工業(yè)控制 > 電子設(shè)計(jì)自動化
[導(dǎo)讀] 摘要:本文針對FPGA實(shí)際開發(fā)過程中,出現(xiàn)故障后定位困難、反復(fù)修改代碼編譯時間過長、上板后故障解決無法確認(rèn)的問題,提出了一種采用仿真的方法來定位、解決故障并驗(yàn)證故障解決方案??梢源蟠蟮墓?jié)約開發(fā)時間,提高

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

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

  問題的提出

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

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

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

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

 ?、凵习逯匦逻M(jìn)行驗(yàn)證時,如果這個bug的出現(xiàn)的幾率很小,短時間內(nèi)不再復(fù)現(xiàn),并不能說明在極端情況下的故障真的被解決了。

  舉例說明:

  

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

  圖2 SignalTap抓信號界面

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

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

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

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

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

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

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

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

  仿真解決故障的方法

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

  圖3 SignalTap II LiST File界面

 ?、賹ug出現(xiàn)時SignalTap抓的信號保存成文檔文件

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

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

  圖3中界面上半部分顯示的是list對信號個數(shù)及信號名的描述,下半部分是采樣點(diǎn)所對應(yīng)的信號值,帶h的表示是十六進(jìn)制數(shù)值。

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

  

  圖4 “另存為”選項(xiàng)界面

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

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

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

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

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

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

  begin

  data<=ram[addr];

  addr<=addr+1'b1;

  end

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

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

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

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

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

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

  

  

  圖5 modelsim環(huán)境下復(fù)現(xiàn)的出錯數(shù)據(jù)

  

  圖6 修改程序后相同條件下的輸出數(shù)據(jù)

  

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

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

  總結(jié)

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


 

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

仿真技術(shù)帶來了諸多便利與優(yōu)勢。 仿真技術(shù)具有成本低、適應(yīng)范圍廣和提供豐富信息的優(yōu)勢。首先,其成本相對較低。進(jìn)行仿真時,無需制作實(shí)體模型或購買昂貴的測量設(shè)備,大大節(jié)省了資源和時間。同時,仿真模型的大小可隨心所欲地調(diào)整,無論...

關(guān)鍵字: 互聯(lián)網(wǎng) 仿真技術(shù)

在?COMSOL 主題日油氣專場活動中,眾多行業(yè)精英匯聚一堂,與會的專家和學(xué)者們深入探討了多物理場仿真技術(shù)在油氣領(lǐng)域的前沿應(yīng)用及獨(dú)特優(yōu)勢。 上海 2025年5月22日 /美通社/ -- 全球領(lǐng)先的仿真軟件提供商C...

關(guān)鍵字: COMSOL 仿真軟件 仿真技術(shù) 新能源

但是,該項(xiàng)目需要使用信號發(fā)生器等形式的外部硬件。我認(rèn)為創(chuàng)建一個使用PYNQ的示例可能是一個好主意,它使我們能夠使用Python生成任意信號,過濾它并繪制結(jié)果波形。

關(guān)鍵字: FIR濾波器 FPGA設(shè)計(jì) 信號發(fā)生器

COMSOL 2024年度中國區(qū)用戶年會匯聚了COMSOL 軟件的廣大用戶群體。眾多領(lǐng)域的專家學(xué)者和工程師深入探討了多物理場仿真技術(shù)在各行業(yè)中的創(chuàng)新應(yīng)用和如何通過仿真推動技術(shù)突破的獨(dú)到見解,為與會者提供了寶貴的洞見和啟發(fā)...

關(guān)鍵字: COMSOL 仿真技術(shù) 微信 仿真模擬

COMSOL主題日清潔能源專場匯聚行業(yè)精英,共同探討多物理場仿真技術(shù)在清潔能源領(lǐng)域的前沿應(yīng)用與優(yōu)勢。與會專家和學(xué)者深入解析如何使用多物理場仿真賦能清潔能源技術(shù)的創(chuàng)新與突破。 上海2024年9月25日 /美通社/ --...

關(guān)鍵字: 清潔能源 COMSOL 仿真技術(shù) APP

在COMSOL主題日系列活動光學(xué)專場中,多位行業(yè)專家分享了多物理場仿真技術(shù)在光學(xué)領(lǐng)域的廣泛應(yīng)用及其所展現(xiàn)出的領(lǐng)先優(yōu)勢,深入剖析了如何使用多物理場仿真助力光學(xué)領(lǐng)域的技術(shù)創(chuàng)新與突破。 上海2024年8月22日 /美通社/...

關(guān)鍵字: 光學(xué) COMSOL 仿真技術(shù) 仿真軟件

在FPGA(現(xiàn)場可編程門陣列)設(shè)計(jì)和Verilog編程中,無符號數(shù)(Unsigned Numbers)和有符號數(shù)(Signed Numbers)的正確使用至關(guān)重要。這兩種數(shù)據(jù)類型在表示方法、運(yùn)算規(guī)則以及處理方式上存在顯著...

關(guān)鍵字: FPGA設(shè)計(jì) Verilog 無符號數(shù) 有符號數(shù)

在數(shù)字電路設(shè)計(jì)中,F(xiàn)PGA(現(xiàn)場可編程門陣列)憑借其高度的靈活性和可重配置性,成為了實(shí)現(xiàn)復(fù)雜邏輯和算法的重要平臺。為了提高設(shè)計(jì)效率和復(fù)用性,參數(shù)化模塊的設(shè)計(jì)顯得尤為重要。參數(shù)化模塊允許設(shè)計(jì)者通過調(diào)整模塊內(nèi)部的參數(shù)來改變其...

關(guān)鍵字: FPGA設(shè)計(jì) Verilog VHDL

在FPGA(現(xiàn)場可編程門陣列)設(shè)計(jì)中,性能和資源利用率的量化是衡量設(shè)計(jì)質(zhì)量和效率的關(guān)鍵指標(biāo)。通過精確量化這些指標(biāo),設(shè)計(jì)者可以評估設(shè)計(jì)的實(shí)際效果,進(jìn)而對設(shè)計(jì)進(jìn)行優(yōu)化和改進(jìn)。本文將深入探討FPGA設(shè)計(jì)中性能與資源利用率的量化...

關(guān)鍵字: FPGA設(shè)計(jì) 現(xiàn)場可編程門陣列

在FPGA(現(xiàn)場可編程門陣列)的設(shè)計(jì)過程中,約束文件扮演著至關(guān)重要的角色。它們不僅是連接設(shè)計(jì)邏輯與物理實(shí)現(xiàn)之間的橋梁,更是確保設(shè)計(jì)性能、可靠性和可測試性的關(guān)鍵工具。特別是在處理復(fù)雜的時鐘域管理和數(shù)據(jù)同步問題時,約束文件的...

關(guān)鍵字: FPGA設(shè)計(jì) 約束文件 時鐘域
關(guān)閉