《電子技術應用》
您所在的位置:首頁 > EDA與制造 > 設計應用 > 應用EDA仿真技術解決FPGA設計開發中故障的方法
應用EDA仿真技術解決FPGA設計開發中故障的方法
深圳中興通訊股份有限公司湯琥 哈工大學信息與通信工程學院 張在興
摘要: FPGA近年來在越來越多的領域中應用,很多大通信系統(如通信基站等)都用其做核心數據的處理。但是過長的編譯時間,在研發過程中使得解決故障的環節非常令人頭痛。本文介紹的就是一種用仿真方法解決故障從而減少研發過程中的編譯次數,最終達到準確定位故障、縮短解決故障時間的目的。文例所用到的軟件開發平臺為Altera公司的Quartus II,仿真工具為ModelSim。
Abstract:
Key words :

 

        本文針對FPGA實際開發過程中,出現故障后定位困難、反復修改代碼編譯時間過長、上板后故障解決無法確認的問題,提出了一種采用仿真的方法來定位、解決故障并驗證故障解決方案??梢源蟠蟮墓澕s開發時間,提高開發效率。
  FPGA近年來在越來越多的領域中應用,很多大通信系統(如通信基站等)都用其做核心數據的處理。但是過長的編譯時間,在研發過程中使得解決故障的環節非常令人頭痛。本文介紹的就是一種用仿真方法解決故障從而減少研發過程中的編譯次數,最終達到準確定位故障、縮短解決故障時間的目的。文例所用到的軟件開發平臺為Altera公司的Quartus II,仿真工具為ModelSim。
  問題的提出
  系統開發在上板調試過程中,有時候出現的bug是很極端的情況或很少出現的情況,而現在通常的做法是:在故障出現的時候通過SignalTap 把信號抓出來查找其問題的所在、修改程序;在改完版本后,先要對整個工程進行重新編譯,然后再上板跑版本進行驗證,看看故障是否解決。
  這樣就會出現三個問題:
  ①有時候故障很難定位,只知道哪個模塊出錯,很難定位到具體的信號上,給抓信號帶來麻煩。如果故障定位不準確,漏抓了關鍵信號,則需要重新在 SignalTap里添加信號、編譯版本并再次上板定位故障,浪費時間。
  ②故障定位后,修改代碼還需要再編譯一次產生新版本的下載文件,修改后若還有問題則要重復這一過程,這樣從故障定位到修改完成需要很多次編譯。
 ?、凵习逯匦逻M行驗證時,如果這個bug的出現的幾率很小,短時間內不再復現,并不能說明在極端情況下的故障真的被解決了。
  舉例說明:
  例如在一個基帶系統的FPGA邏輯版本中,輸出模塊調用了一個異步FIFO,某一時刻FIFO已空的情況下多讀了一個數據,產生了bug,如圖 1所示。
圖1 SignalTap抓出的bug出現時的數據
  該輸出模塊的功能是判斷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的方法是可行的。步驟如下:
 ?、賹ug出現時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所示。
 
 
圖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 ModelSim環境下復現的出錯數據
  把圖5和圖1進行比較,可見通過這種方法我們在仿真環境下建立了bug出錯時的環境,得到相同的輸出出錯數據。
  ③修改程序后在仿真環境驗證修改是否成功
  修改程序后,我們只要使用同樣的環境進行仿真,并且有針對性的觀察bug是否解決。本例中出現bug的原因是使用了異步FIFO,改成同步 FIFO后,問題應該就會解決,我們可以通過仿真驗證。修改程序后仿真的波形如圖6所示。
圖6 修改程序后相同條件下的輸出數據
 
  由圖6可見,修改后相同的條件FIFO讀出4個數,說明沒有讀空,符合要求,bug解決。圖7為版本編譯后上板使用SignalTap抓取的信號波形,以作比較。
圖7 修改程序后SignalTap抓的信號
 
  比較后易見,波形完全相同,說明方法可行。
  總結
  文中描述的方法可針對各種的故障的解決。在故障出現時,只需定位出錯的模塊,這些模塊內嵌一些子模塊也無妨;抓信號時將故障模塊的輸入輸出信號抓出即可;利用輸入信號重建故障環境,若仿真輸出信號和所抓輸出信號相同,說明故障環境建立正確;用這個仿真平臺就可以具體定位是哪個子模塊、哪個信號出錯,而不需要在SignalTap中把這些信號抓出來;并且在修改代碼后可以驗證是否修改成功,節省時間,很明確的證明故障真的被解決了,事半功倍。
此內容為AET網站原創,未經授權禁止轉載。
热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>
          亚洲愉拍自拍另类高清精品| 欧美激情 亚洲a∨综合| 亚洲精品中文字幕有码专区| 久久精品国产综合精品| 欧美三级不卡| 一区二区三区av| 狠狠色伊人亚洲综合成人| 一本久道久久综合中文字幕| 久久超碰97中文字幕| 久久亚洲私人国产精品va媚药| 免费在线观看精品| 老鸭窝91久久精品色噜噜导演| 激情懂色av一区av二区av| 红桃视频亚洲| 国产精品国产三级国产普通话三级| 亚洲精品久久久久久久久久久久| 亚洲视频图片小说| 欧美亚州韩日在线看免费版国语版| 欧美激情一区二区三区在线视频观看| 午夜精品久久一牛影视| 欧美日韩一视频区二区| 99精品欧美| 欧美日韩一区视频| 女女同性女同一区二区三区91| 国产午夜精品理论片a级大结局| 欧美日本精品| 亚洲欧洲精品一区| 欧美自拍丝袜亚洲| 国产精品99久久久久久久久久久久| 9i看片成人免费高清| 国产精品videossex久久发布| 国产精品成人观看视频免费| 日韩午夜三级在线| 欧美激情亚洲综合一区| 亚洲欧美激情视频| 91久久精品一区| 久久精品免费电影| 亚洲一区观看| 亚洲精品久久久久久久久| 欧美性色aⅴ视频一区日韩精品| 欧美在线电影| 裸体一区二区三区| 国产精品theporn88| 久久影音先锋| 亚洲精品乱码久久久久久| 国产精品久久网站| 久久久欧美精品sm网站| 欧美三级午夜理伦三级中文幕| 一本久久精品一区二区| 亚洲国产专区校园欧美| 一本综合久久| 国产欧美精品在线| 久久久91精品国产一区二区精品| 国产精品久久久久久久久久免费看| 欧美韩日亚洲| 亚洲女与黑人做爰| 欧美一级理论性理论a| 日韩视频在线你懂得| 一本色道精品久久一区二区三区| 国产目拍亚洲精品99久久精品| 欧美大尺度在线观看| 中文久久精品| 国产精品香蕉在线观看| 激情视频一区二区| 午夜欧美不卡精品aaaaa| 一区二区高清在线| 亚洲自拍都市欧美小说| 亚洲精品久久久久中文字幕欢迎你| 欧美成人精精品一区二区频| 老司机免费视频一区二区| 一本到高清视频免费精品| 欧美视频手机在线| 国产精品嫩草99av在线| 亚洲尤物视频在线| 亚洲黄色尤物视频| 国产一区二区三区丝袜| 国产视频在线观看一区二区三区| 欧美一区二区精品| 久久国产一区| 欧美日韩国产高清| 欧美激情四色| 欧美二区乱c少妇| 国产一区二区精品久久91| 国模私拍一区二区三区| 亚洲国产精品一区二区三区| 校园春色国产精品| 亚洲视频观看| 亚洲欧美日韩一区二区三区在线观看| 久久精品一区中文字幕| 亚洲网站在线| 国产一区在线播放| 欧美日韩免费在线视频| 亚洲国产成人久久| 欧美—级高清免费播放| 亚洲免费观看高清在线观看| 国产欧美91| 中国成人黄色视屏| 欧美日韩视频在线观看一区二区三区| 一区二区动漫| 欧美亚洲一级| 欧美二区在线观看| 欧美日韩在线免费| 欧美日韩国产一级| 久久人人爽爽爽人久久久| 亚洲视频一区二区免费在线观看| 亚洲手机成人高清视频| 欧美精品一区二区精品网| 亚洲综合电影一区二区三区| 国产人久久人人人人爽| 久久国产精品网站| 一本色道久久综合亚洲二区三区| 在线观看免费视频综合| 美日韩免费视频| 久久久久久久国产| 久久成人一区二区| 欧美视频在线观看一区二区| 久久男人资源视频| 在线精品亚洲| 国产麻豆精品theporn| 欧美黄网免费在线观看| 国户精品久久久久久久久久久不卡| 国产精品一区二区视频| 国产亚洲观看| 亚洲精品在线观看免费| 国产九色精品成人porny| 久久国产精品久久久久久久久久| 久久久久久国产精品一区| 国产亚洲精品成人av久久ww| 国产三级精品在线不卡| 欧美午夜精品久久久久久孕妇| 欧美激情第二页| 国产午夜精品久久久| 亚洲高清在线视频| 国产在线视频欧美| 黄色成人av网站| 中文久久乱码一区二区| 国产精品高潮呻吟久久av无限| 男同欧美伦乱| 狠狠色丁香婷婷综合影院| 欧美无乱码久久久免费午夜一区| 亚洲免费观看在线观看| 久久国产精品久久精品国产| 亚洲综合丁香| 国产精品国产三级国产aⅴ入口| 久久这里有精品15一区二区三区| 亚洲激情综合| 91久久精品美女| 亚洲一区日韩| 亚洲视频 欧洲视频| 激情久久中文字幕| 国产欧美日韩综合一区在线播放| 欧美在线www| 欧美啪啪成人vr| 欧美福利小视频| 久久亚洲综合色一区二区三区| 一区二区欧美激情| 亚洲风情在线资源站| 国产精品一区二区久久精品| 激情成人av在线| 亚洲高清在线观看| 韩日欧美一区| 日韩一区二区精品在线观看| 亚洲一区三区电影在线观看| 欧美视频在线看| 欧美亚洲日本一区| 亚洲综合视频一区| 国产精品国产三级国产专区53| 欧美激情综合色综合啪啪| 国产精品久久久久三级| 国产综合色精品一区二区三区| 久久久久91| 午夜精品区一区二区三| 亚洲免费影视| 免费欧美高清视频| 99天天综合性| 久久久精品国产一区二区三区| 在线观看日韩av先锋影音电影院| 亚洲国语精品自产拍在线观看| 亚洲午夜精品久久久久久浪潮| 国产精品一区二区欧美| 91久久嫩草影院一区二区| 亚洲国产欧美一区二区三区丁香婷| 美女精品国产| 99国产欧美久久久精品| 欧美久久久久中文字幕| 激情综合色丁香一区二区| 久久久精品一区| 国产精品二区在线观看| 国产精品热久久久久夜色精品三区| 欧美亚州韩日在线看免费版国语版| 亚洲国产精品一区二区第四页av| 国产精品免费福利| 国产精品大片免费观看| 欧美国产日韩一区二区在线观看| 免费久久精品视频| 欧美人在线观看| 韩国成人福利片在线播放| 久久久久国产精品麻豆ai换脸| 亚洲国产三级网| 老牛嫩草一区二区三区日本| 久久久不卡网国产精品一区| 欧美精品在欧美一区二区少妇| 亚洲国产天堂久久国产91| 亚洲系列中文字幕| 99re66热这里只有精品4| **网站欧美大片在线观看| 亚洲国产精品一区在线观看不卡| 亚洲乱码久久| 国产亚洲欧美色| 亚洲欧美中文在线视频| 久久婷婷人人澡人人喊人人爽| 国产视频在线观看一区二区三区| 欧美精品在线视频观看| 日韩性生活视频| 欧美午夜一区二区三区免费大片| 欧美激情一区二区三区在线视频| 欧美乱人伦中文字幕在线| 国产日韩欧美日韩大片| 一本色道久久综合狠狠躁篇怎么玩| 一本久道久久久| 国产精品美女久久久久aⅴ国产馆| 国产精品美女午夜av| 久久天天躁夜夜躁狠狠躁2022| 久久久综合网| 国产精品久久久久久久久搜平片| 午夜精品久久久久久久久久久久久| 久久成人资源| 亚洲免费成人av电影| 欧美亚洲综合另类| 国产精品99久久久久久久久| 欧美一级久久久久久久大片| 亚洲天堂av综合网| 国产精品一区二区久久| 日韩一级二级三级| 媚黑女一区二区| 久久久精品国产99久久精品芒果| 欧美www在线| 91久久综合| 欧美日韩国产经典色站一区二区三区| 国产色婷婷国产综合在线理论片a| 亚洲伦理在线观看| 欧美三级韩国三级日本三斤| 欧美日韩国产色视频| 亚洲已满18点击进入久久| 亚洲精品孕妇| 在线观看视频日韩| 蜜臀av在线播放一区二区三区| 亚洲第一偷拍| 欧美亚州韩日在线看免费版国语版| 亚洲一区免费| 亚洲视频一二三| 亚洲综合色噜噜狠狠| 免费h精品视频在线播放| 怡红院精品视频在线观看极品| 日韩视频免费在线| 亚洲毛片一区| 性久久久久久久久| 国产视频在线观看一区| 精品成人一区二区三区| 99视频在线精品国自产拍免费观看| 香蕉亚洲视频| 销魂美女一区二区三区视频在线| 欧美日韩美女一区二区| 欧美制服丝袜第一页| 久久精品免费播放| 国内精品视频666| 欧美在线短视频| 亚洲激情电影中文字幕| 亚洲欧美日韩国产成人精品影院| 亚洲二区免费| 国产精品欧美久久| 久久精品国产v日韩v亚洲| 国产精品成av人在线视午夜片| av成人福利| 亚洲午夜av在线| 欧美成人精品不卡视频在线观看| 欧美麻豆久久久久久中文| 亚洲欧美成人一区二区在线电影| 欧美日韩福利在线观看| 亚洲欧洲三级电影| 亚洲在线黄色| 国内精品久久久久影院色| 性欧美大战久久久久久久免费观看| 国产主播精品在线| 久久精品30| 欧美在线免费观看视频| 久久久av毛片精品| 亚洲人成网站777色婷婷| 国产精品毛片va一区二区三区| 欧美日韩国产一区二区三区| 亚洲黄色免费网站| 亚洲国内自拍| 久久精品视频在线观看| 国产精品高潮在线| 亚洲第一伊人| 国产精品欧美日韩一区| 一区二区高清视频| 亚洲综合色自拍一区| 欧美成人网在线| 欧美日一区二区三区在线观看国产免| 久久精品伊人| 欧美一区三区三区高中清蜜桃| 国产一区二区三区高清播放| 欧美日韩一区二区在线播放| 在线午夜精品| 一区国产精品| 欧美成人一区二区在线| 日韩午夜在线视频| 欧美色欧美亚洲高清在线视频| 亚洲天堂免费观看| 国产日本欧美一区二区| 91久久精品国产91性色tv| 国产精品视屏| 在线欧美小视频| 国产精品地址| 欧美日韩一区二区三区在线看| 久久成人精品无人区| 欧美国产大片| 一区二区三区日韩欧美精品| 麻豆精品视频在线| 亚洲宅男天堂在线观看无病毒| 国产欧美日本在线| 99精品热视频只有精品10| 国内精品久久久久久久影视蜜臀| 欧美三级第一页| 国产精品视频yy9099| 久久国产主播精品| 一区二区av在线|