<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

EEPW首頁(yè) > 嵌入式系統 > 設計應用 > 仿真器并非萬(wàn)能之神

仿真器并非萬(wàn)能之神

作者: 時(shí)間:2009-12-18 來(lái)源:網(wǎng)絡(luò ) 收藏

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

ERROR:NgdBuild:924 - bidirect pad net 'DATA_IO15>' 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_IO15>' has no legal load.

本文引用地址:http://dyxdggzs.com/article/152216.htm


我開(kāi)始嘟嘟囔囔,旁邊的同事瞇起眼睛,像老鷹山姆那樣斜眼著(zhù)我。慶幸的是,我能夠從消息屏幕中的錯誤消息中找到出現錯誤的代碼行。雙擊與兩個(gè)串聯(lián)的緩沖區有關(guān)的第一個(gè)錯誤消息后我找到了以下代碼片段:
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)
我最初的想法是“啊哈,我弄出了一個(gè)三態(tài)端口與多路復用器,多么好的想法呀?”。聰明而又經(jīng)驗豐富的讀者一眼就能看清這個(gè)問(wèn)題,但是這種錯誤會(huì )讓 FPGA 新手難倒好幾天,讓人寢食難安,心力憔悴。我盯著(zhù)這三行代碼看了半分鐘,意識到應該隨便找張紙畫(huà)出我最初的意圖:

現在我認識到,我之前認為綜合引擎會(huì )明白我并不想在器件中加入高阻抗信號。實(shí)際上,當我再次查看錯誤與警告消息之后才清楚它就是這么干的:

如果您是一名出色的 FPGA 設計人員并且確實(shí)閱讀了數據手冊與程序庫指南,那么您立刻就會(huì )明白這是不可能的事情。我所知道的任何 FPGA 布線(xiàn)資源都不會(huì )允許這種連接。


上一頁(yè) 1 2 下一頁(yè)

關(guān)鍵詞: 萬(wàn)能 并非 仿真器

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>