當(dāng)前位置:首頁 > 嵌入式 > 嵌入式教程
[導(dǎo)讀]仿真器并非萬能之神

  現(xiàn)在已經(jīng)到了關(guān)鍵時刻。我們已經(jīng)確定了電路板的設(shè)計原型,現(xiàn)正送回實驗室進(jìn)行測試。由于后期規(guī)格更改,以及在布線后信號完整性分析過程中發(fā)現(xiàn)的問題,這個項目比原計劃滯后了兩周。這對我而言并非壞事,因為說實話我需要這兩周時間,以便將仿真用的測試臺準(zhǔn)備得停停當(dāng)當(dāng)。
    此項目采用 VHDL 編碼,而且我采取了一種循規(guī)蹈矩的方案——保持層級結(jié)構(gòu),所有黑盒子 (Black-box)、原語和宏指令都采用全局聲明(以便完成的設(shè)計具有更高的可移植性并且可以符合 IEEE 標(biāo)準(zhǔn)),而且主要是一種 RTL 類型的方案。當(dāng)然,我的部分設(shè)計具有行為屬性,要不然就是我完全忽略了 HDL 的主要優(yōu)勢 ––– 應(yīng)用行為抽象的能力。
      因此我多費(fèi)了點(diǎn)事,不過現(xiàn)在我可以開始啟動仿真工作了。仿真進(jìn)行了數(shù)毫秒,我對結(jié)果相當(dāng)滿意。我可以通過 Wave 編輯器測量占空比與周期得到了我希望的結(jié)果,復(fù)位邏輯按照我所預(yù)測的時鐘周期數(shù)出現(xiàn),時鐘合成器運(yùn)行正確無誤。而且I/O 信號顯示出我所希望的 1、0 以及三態(tài)。值得一提的是,我很清楚地記得我在幾千行代碼中,已經(jīng)謹(jǐn)慎地避免了異步過程和時鐘域交叉,最重要的是解決信號 (Resolved signal)。我想起學(xué)科導(dǎo)師曾經(jīng)略帶諷刺地說‘PCB 與芯片設(shè)計師才用三態(tài)’。
      開始時的信心百倍讓我想冒點(diǎn)險,我決定將設(shè)計綜合在一起。幸運(yùn)的是,我使用的工具允許我輕松嘗試多種不同綜合引擎,因此我開始從其中一個內(nèi)置引擎入手。因為項目中采用了幾種復(fù)雜的行為狀態(tài)機(jī),需要花點(diǎn)時間進(jìn)行優(yōu)化,不過完成時出現(xiàn)了少數(shù)幾個次要警告。到目前為止一切順利。
我的信心更足了一點(diǎn),接著繼續(xù)點(diǎn)擊“創(chuàng)建 (Build)”按鈕,接下來工作流程的“映射 (Map)”、“轉(zhuǎn)換 (Translate)”、“布局布線 (Place and Route)”以及“位文件生成 (Bit File Generation)”,這些操作全部通過與芯片廠商工具的命令行接口在后臺執(zhí)行。映射設(shè)計進(jìn)行了大約一分半就停止了,顯示出一條有關(guān) IBUFT 與 OBUFT 的難懂信息。唉……!我知道自己的好日子到頭了,真是大夢初醒啊!
      我接下來通常會聳聳肩膀,然后切換到 FPGA 廠商的綜合器,看看其優(yōu)化器能否產(chǎn)生可以順利布局與布線的結(jié)果。因此,點(diǎn)擊幾下鼠標(biāo)之后我開始重新運(yùn)行 “綜合(Synthesis)”與“創(chuàng)建(Build)”。這次我注意到綜合多少比以前快了一點(diǎn)。我心中燃起希望,因為廠商的引擎在進(jìn)行較少程度的優(yōu)化,而且將產(chǎn)生盡管更龐大、但更精確的實施方案。然后在映射過程中在同一地方嘎然而止,同樣出現(xiàn)了讓人費(fèi)解的錯誤消息,然后是一條警告:
 
ERROR:NgdBuild:924 - bidirect pad net ‘DATA_IO<15>‘ is driving non-buffer
   primitives:
     pin I1 on block U_dspboard_fpga/fb_epb_intf_inst/n12g with type AND2B1
WARNING:NgdBuild:465 - bidirect pad net ‘DATA_IO<15>‘ has no legal load.


     我開始嘟嘟囔囔,旁邊的同事瞇起眼睛,像老鷹山姆那樣斜眼著我。慶幸的是,我能夠從消息屏幕中的錯誤消息中找到出現(xiàn)錯誤的代碼行。雙擊與兩個串聯(lián)的緩沖區(qū)有關(guān)的第一個錯誤消息后我找到了以下代碼片段:
DATA_IO  <= DATA_IN when CNTL_IN(4) = ‘0‘ -- write to Ext. Device
                    else (others => ‘Z‘);
DATA_OUT <= DATA_IO; -- data from core to CF (5000_0050)
      我最初的想法是“啊哈,我弄出了一個三態(tài)端口與多路復(fù)用器,多么好的想法呀?”。聰明而又經(jīng)驗豐富的讀者一眼就能看清這個問題,但是這種錯誤會讓 FPGA 新手難倒好幾天,讓人寢食難安,心力憔悴。我盯著這三行代碼看了半分鐘,意識到應(yīng)該隨便找張紙畫出我最初的意圖:
 
     現(xiàn)在我認(rèn)識到,我之前認(rèn)為綜合引擎會明白我并不想在器件中加入高阻抗信號。實際上,當(dāng)我再次查看錯誤與警告消息之后才清楚它就是這么干的:
 
     如果您是一名出色的 FPGA 設(shè)計人員并且確實閱讀了數(shù)據(jù)手冊與程序庫指南,那么您立刻就會明白這是不可能的事情。我所知道的任何 FPGA 布線資源都不會允許這種連接。[!--empirenews.page--]
我首先認(rèn)識到可以用原理圖當(dāng)畫出以下簡單的 IOBUF 電路:
 
     由于DATA_IO 與 DATA_OUT連接到較高層文檔中的 IO 接口,綜合器會插入用于 DATA_OUT的適當(dāng) OBUF,因此我無需在此畫出。這個例子可以很好地說明了原理圖與方框圖設(shè)計方案如何能實實在在地減少未知錯誤。我的第二個更加驚人的發(fā)現(xiàn)是我在 VHDL 代碼中編寫的內(nèi)容能夠全部得到正確仿真,這里顯示出了我實際預(yù)期的信號變化。當(dāng)然,我始終明白能夠仿真與能夠綜合之間的區(qū)別。這里有一個新的誤解 —— 我可以無錯地仿真并合成我的設(shè)計。我敢斷言,現(xiàn)在應(yīng)該被問:“它可以仿真,那么可以合成嗎?可以被映射嗎?”
      這個場景是我虛構(gòu)的,盡管它出自我親身經(jīng)歷過的真實事件。我曾經(jīng)與許多喜歡在設(shè)計流程中使用 VHDL 和 Verilog 的 FPGA 設(shè)計人員深入探討過。我和他們有一致的看法,就是他們的大多數(shù)設(shè)計對于基于原理圖的方法來說過于復(fù)雜。也就是說,您是否主要通過 RTL 進(jìn)行設(shè)計。HDL 的發(fā)明可減少描繪邏輯函數(shù)的工作量,因為門電路與觸發(fā)電路的數(shù)量太多,也太繁復(fù)。然而, FPGA(和 ASIC)一直繼續(xù)遵循著摩爾定律。設(shè)計也是如此,復(fù)雜到使用VHDL 或 Verilog 設(shè)計會把你帶入泥潭,讓你再也看不清整體設(shè)計意圖。上面問題就是例證。
      設(shè)計人員需要保持他們設(shè)計的領(lǐng)先地位。我深信他們將別無選擇地這么做 —— 采用更高端的方法來贏得時間和自由,從而可以集中精力進(jìn)行其產(chǎn)品最重要部分的設(shè)計,即在市場上能使他們脫穎而出的部分。這個行業(yè)正在面臨的挑戰(zhàn)是:技能嫻熟的資深設(shè)計人員必須放下架子來使用與工具配套提供的免費(fèi)的IP,而不是自己親手通過 HDL 把它們重新出來。我能理解這個挑戰(zhàn):作為一個真正的工程設(shè)計迷,我所做的應(yīng)該是這個世界上許多人都做不到的(或者說我也相信)。不過事實上,如果我想設(shè)計更好的產(chǎn)品,并且更快地完成,我就必須站在別人的肩上,對他說“謝謝”,然后采用方框圖的方法迅速將我的系統(tǒng)組合出來。接下來我就可以專心致力于設(shè)計我的創(chuàng)意,并且把它集成到整體系統(tǒng)中,使整個系統(tǒng)更加可靠并出類拔萃。

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

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉