《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 解決方案 > FPGA設計開發中應用仿真技術解決故障的方法

FPGA設計開發中應用仿真技術解決故障的方法

2016-12-08
關鍵詞: FPGA 仿真

本文針對FPGA實際開發過程中,出現故障后定位困難、反復修改代碼編譯時間過長、上板后故障解決無法確認的問題,提出了一種采用仿真的方法來定位、解決故障并驗證故障解決方案。可以大大的節約開發時間,提高開發效率。

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

問題的提出
系統開發在上板調試過程中,有時候出現的bug是很極端的情況或很少出現的情況,而現在通常的做法是:在故障出現的時候通過SignalTap把信號抓出來查找其問題的所在、修改程序;在改完版本后,先要對整個工程進行重新編譯,然后再上板跑版本進行驗證,看看故障是否解決。
這樣就會出現三個問題:
①有時候故障很難定位,只知道哪個模塊出錯,很難定位到具體的信號上,給抓信號帶來麻煩。如果故障定位不準確,漏抓了關鍵信號,則需要重新在SignalTap里添加信號、編譯版本并再次上板定位故障,浪費時間。
②故障定位后,修改代碼還需要再編譯一次產生新版本的下載文件,修改后若還有問題則要重復這一過程,這樣從故障定位到修改完成需要很多次編譯。
③上板重新進行驗證時,如果這個bug的出現的幾率很小,短時間內不再復現,并不能說明在極端情況下的故障真的被解決了。
舉例說明:

圖1 SignalTap抓出的bug出現時的數據

圖2 SignalTap抓信號界面


例如在一個基帶系統的FPGA邏輯版本中,輸出模塊調用了一個異步FIFO,某一時刻FIFO已空的情況下多讀了一個數據,產生了bug,如圖1所示。
該輸出模塊的功能是判斷FIFO中是否有大于4個數據可讀出,若大于則連續輸出4個數據作為一組。系統中采用異步FIFO的內部讀數據指針來做判斷,而異步FIFO讀寫數據需要跨時鐘域,需要至少2個時鐘周期的握手時間,導致數據指針不準確。在判斷的時鐘沿,雖然顯示有超過4個的數據可讀,但是因為握手時間的延遲實際上FIFO中可能只有3個數據。

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

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

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

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

定位好錯誤信號的具體位置后,修改代碼,再用相同的條件進行仿真。這樣可以通過對修改前后輸出數據的對比,很直觀的驗證修改是否成功,從而在修改成功后只需編譯一次即可,節省時間。
上板后bug不復現也可以排除是由于極端情況很難滿足造成的,去除了后顧之憂,徹底解決了故障。

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

圖3 SignalTap II List File界面


①將bug出現時SignalTap抓的信號保存成文檔文件

Quartus II 平臺用SignalTap抓到信號的界面如圖2所示。
在信號名稱上單擊右鍵,選擇圖2所示Create SignalTap II List File選項,生成如圖3格式界面。
圖3中界面上半部分顯示的是list對信號個數及信號名的描述,下半部分是采樣點所對應的信號值,帶h的表示是十六進制數值。

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

圖4 “另存為”選項界面

此后可以把這個文本文件中無用的描述刪掉,只留SignalTap抓出來的數據(空格、h等符號也要刪掉),另存為.dat文件供仿真使用。
有了故障出現時的輸入數據,我們就可以在仿真環境下構建故障出現的條件。

②利用.dat文件建立bug出現的條件
用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

復現bug存在條件時,需將模塊的輸入信號與ram中的數據位相對應,仿真文件調用模塊時,將寄存器data對應位作為輸入接入即可。
在仿真環境中復現bug波形如圖5所示。
把圖5和圖1進行比較,可見通過這種方法我們在仿真環境下建立了bug出錯時的環境,得到相同的輸出出錯數據。

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

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

圖5 modelsim環境下復現的出錯數據

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

圖7 修改程序后SignalTap抓的信號
比較后易見,波形完全相同,說明方法可行。

總結

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

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          亚洲激情成人| 亚洲国产精品一区在线观看不卡| 蜜桃av噜噜一区二区三区| 日韩一本二本av| 久久99在线观看| 亚洲欧美国产精品桃花| 玉米视频成人免费看| 久久综合影视| 激情91久久| 亚洲国产成人精品久久久国产成人一区| 国产亚洲成av人片在线观看桃| 久久婷婷国产综合精品青草| 国产精品视屏| 亚洲欧美综合一区| 欧美成人一区二区| 一本一本a久久| 国产精品xnxxcom| 亚洲日本免费电影| 夜夜嗨av色一区二区不卡| 亚洲精品久久久久久下一站| 欧美日韩视频第一区| 亚洲欧美在线免费| 国产精品成人在线| 久久久久国产精品人| 国产日本欧美视频| 国产精品海角社区在线观看| 久热精品视频在线| 91久久久久| 免费久久精品视频| 亚洲欧美日韩国产成人| 久久精品av麻豆的观看方式| 国产精品日日摸夜夜添夜夜av| 美女露胸一区二区三区| 亚洲日韩成人| 国产一区清纯| 国产精品va在线播放我和闺蜜| 国产老肥熟一区二区三区| 欧美日韩免费观看中文| 久久精品国产久精国产爱| 欧美精品一区二区三区视频| 久久久久国产精品一区二区| 久久米奇亚洲| 在线欧美日韩| 久久成人精品电影| 午夜精品视频网站| 国产精品二区三区四区| 亚洲影视综合| 亚洲黄色有码视频| 国产精品扒开腿做爽爽爽视频| 黑人极品videos精品欧美裸| 久久久久久久久久久久久女国产乱| 久久国产成人| 久久青草欧美一区二区三区| 欧美日韩精品高清| 久久久美女艺术照精彩视频福利播放| 国产午夜亚洲精品不卡| 国产精品成人免费| 久久一区二区三区国产精品| 久久国产婷婷国产香蕉| 狠狠操狠狠色综合网| 亚洲欧美日产图| 久久久精品日韩| 亚洲视频免费看| 久久人人爽爽爽人久久久| 国产美女精品在线| 亚洲精品日韩精品| 欧美中文字幕视频在线观看| 性亚洲最疯狂xxxx高清| 亚洲手机成人高清视频| 在线观看视频一区| 亚洲国产老妈| 黄色日韩网站| 伊人久久久大香线蕉综合直播| 欧美一区不卡| 欧美福利精品| 欧美久久一级| 国产精品久久久久久久第一福利| 欧美精品一区二区三| 欧美一区二视频在线免费观看| 欧美午夜精品理论片a级大开眼界| 99成人在线| 日韩一本二本av| 日韩亚洲视频| 久久免费国产| 精品福利电影| 国语自产精品视频在线看8查询8| 美女诱惑黄网站一区| 在线看欧美日韩| 欧美中文字幕精品| 亚洲无限乱码一二三四麻| 黄色亚洲大片免费在线观看| 午夜在线电影亚洲一区| 99在线精品观看| 麻豆久久婷婷| 欧美日韩国产美女| 欧美性jizz18性欧美| 国产九九精品| 亚洲精品国产精品国自产观看浪潮| 久久国内精品自在自线400部| 伊人狠狠色丁香综合尤物| 狠狠色香婷婷久久亚洲精品| 欧美视频第二页| 久久免费99精品久久久久久| 奶水喷射视频一区| 欧美日韩成人在线播放| 国产精品视频午夜| 亚洲理论在线观看| 亚洲最新色图| 麻豆9191精品国产| 国产精品久久久久一区二区三区共| 欧美日韩一区二区高清| 欧美日韩精品免费观看视频完整| 亚洲已满18点击进入久久| 久久福利电影| 99国产精品99久久久久久| 欧美国产精品中文字幕| 一本色道久久综合狠狠躁篇的优点| 国产精品麻豆va在线播放| 国产丝袜美腿一区二区三区| 亚洲欧美一区二区在线观看| 久久深夜福利免费观看| 国产精品毛片高清在线完整版| 国产永久精品大片wwwapp| 亚洲欧美激情精品一区二区| 欧美午夜电影网| 亚洲免费在线视频| 亚洲人成77777在线观看网| 欧美亚洲综合另类| 黑人巨大精品欧美一区二区小视频| 一本色道久久88亚洲综合88| 一区二区欧美亚洲| 91久久精品一区二区三区| 国产精品乱码人人做人人爱| 久久成人精品电影| 亚洲欧美一区二区三区久久| 欧美激情aⅴ一区二区三区| 欧美日韩国产限制| 一区在线免费| 欧美三级小说| 欧美日产在线观看| 欧美一级久久| 国内精品久久久久影院薰衣草| 国产视频丨精品|在线观看| 亚洲精品四区| 在线观看视频一区二区欧美日韩| 欧美视频不卡| 极品av少妇一区二区| 免费欧美日韩国产三级电影| 欧美午夜激情视频| 9国产精品视频| 亚洲国产91色在线| 日韩亚洲欧美在线观看| 国产精品进线69影院| 毛片精品免费在线观看| 美乳少妇欧美精品| 99精品免费网| 激情av一区二区| 久久久久网址| 午夜精品久久久久久久99樱桃| 久久综合国产精品| 国产亚洲福利一区| 国产精品久久久久久久免费软件| 原创国产精品91| 国产精品久久久久久福利一牛影视| 尤物yw午夜国产精品视频| 久久免费视频观看| 国产午夜精品美女毛片视频| 国产午夜亚洲精品羞羞网站| 午夜伦欧美伦电影理论片| 久久天天狠狠| 久久久久国内| 国产精品羞羞答答| 国产精品欧美日韩一区| 另类尿喷潮videofree| 欧美精品在线免费| 久久阴道视频| 亚洲免费中文| 免费不卡中文字幕视频| 欧美有码视频| 另类人畜视频在线| 欧美国产日韩一区二区| 欧美日韩1区2区3区| 欧美精品一区二区三区一线天视频| 一区二区三区国产在线| 国产精品国内视频| 母乳一区在线观看| 国产欧美日韩视频一区二区三区| 亚洲免费成人| 欧美三级网址| 亚洲欧洲免费视频| 亚洲精品国产日韩| 欧美日本免费| 国产亚洲欧美日韩一区二区| 欧美日韩一卡二卡| 亚洲午夜精品网| 韩日精品中文字幕| 欧美三级午夜理伦三级中视频| 亚洲福利免费| 亚洲专区国产精品| 欧美午夜片在线免费观看| 欧美国产国产综合| 宅男在线国产精品| 老巨人导航500精品| 午夜精品福利一区二区蜜股av| 99re热这里只有精品免费视频| 国产精品一区久久久| 欧美精品激情在线观看| 欧美大胆a视频| 欧美日韩在线观看一区二区三区| 国产亚洲欧洲| 欧美三级午夜理伦三级中文幕| 亚洲国产综合91精品麻豆| 欧美日韩一级大片网址| 亚洲一二三区视频在线观看| 香蕉视频成人在线观看| 另类人畜视频在线| 午夜精品久久久久久| 激情综合中文娱乐网| 亚洲一区二区三区四区中文| 欧美日韩天天操| 国产婷婷精品| 红桃视频一区| 欧美精品综合| 久久夜色精品国产亚洲aⅴ| 一本大道久久精品懂色aⅴ| 欧美一区二区三区在线观看视频| 亚洲免费在线观看视频| 欧美日本在线播放| 久久久一本精品99久久精品66| 国产偷自视频区视频一区二区| 亚洲精品免费一区二区三区| 亚洲二区免费| 激情综合色综合久久| 久久婷婷久久一区二区三区| 久久精品国产久精国产一老狼| 欧美另类变人与禽xxxxx| 亚洲人成精品久久久久| 久久精品国产77777蜜臀| 亚洲成在线观看| 亚洲精品乱码久久久久久日本蜜臀| 国产精品日韩二区| 激情久久五月天| 日韩一区二区久久| 久久久欧美精品| 亚洲欧洲一区二区在线播放| 国产欧美在线观看一区| 国产精品99久久久久久www| 久久美女艺术照精彩视频福利播放| 国产精品久久久久久久久久直播| 国产精品一二三| 亚洲性夜色噜噜噜7777| 欧美色网在线| 亚洲精品综合久久中文字幕| 亚洲国产精品黑人久久久| 久久九九99视频| 国产精品久久网| 国产欧美精品一区| 久久性天堂网| 久久天天综合| 久久婷婷丁香| 久久www免费人成看片高清| 欧美激情亚洲激情| 一本大道久久精品懂色aⅴ| 狠狠爱成人网| 一本色道精品久久一区二区三区| 亚洲精品123区| 欧美不卡激情三级在线观看| 亚洲欧洲免费视频| 午夜久久久久| 在线成人黄色| 久久精品中文| 一本一本久久a久久精品综合妖精| 日韩一级大片在线| 国际精品欧美精品| 欧美sm重口味系列视频在线观看| 久久精品国产综合精品| 国模精品一区二区三区| 久久精品国产亚洲高清剧情介绍| 久久久久99精品国产片| 亚洲免费视频中文字幕| 欧美激情按摩| 久久精品国产999大香线蕉| 欧美韩国日本一区| 亚洲国内自拍| 国产婷婷色综合av蜜臀av| 黄色精品网站| 欧美日韩中文| 亚洲女性喷水在线观看一区| 一本大道久久a久久综合婷婷| 亚洲国产精品123| 欧美一级日韩一级| 欧美日韩在线免费视频| 欧美大片网址| 欧美日韩精品是欧美日韩精品| 这里只有精品视频在线| 欧美成人性生活| 国产一区亚洲一区| 亚洲精品一区二区三区樱花| 国产一区二区三区黄| 欧美国产一区视频在线观看| 久久婷婷av| 午夜欧美大尺度福利影院在线看| 黑人中文字幕一区二区三区| 国产欧美日韩一区二区三区在线观看| 国产日韩精品久久| 久久噜噜亚洲综合| 欧美日韩国产电影| 免费欧美电影| 欧美一区二区视频观看视频| 国产精品国产三级国产专播品爱网| 国产亚洲一区二区三区在线观看| 亚洲欧美变态国产另类| 亚洲一区免费观看| 99热在这里有精品免费| 国模叶桐国产精品一区| 亚洲国产精品一区二区第一页| 亚洲成人自拍视频| 国产精品一区二区三区久久| 久久综合给合久久狠狠狠97色69| 国产日韩精品视频一区二区三区| 欧美69wwwcom| 一本色道久久综合亚洲精品婷婷| 亚洲国产欧美在线| 亚洲经典自拍| 国产亚洲女人久久久久毛片| 在线中文字幕日韩| 欧美噜噜久久久xxx| 亚洲高清不卡在线观看|