下載本文檔
版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、 仿真器并非萬(wàn)能仿真器并非萬(wàn)能現(xiàn)在已經(jīng)到了關(guān)鍵時(shí)刻。我們已經(jīng)確定了電路板的設(shè)計(jì)原型,現(xiàn)正送回實(shí)驗(yàn)室進(jìn)行測(cè)試。由于后期規(guī)格更改,以及在布線(xiàn)后信號(hào)完整性分析過(guò)程中發(fā)現(xiàn)的問(wèn)題,這個(gè)項(xiàng)目比原計(jì)劃滯后了兩周。這對(duì)我而言并非壞事,因?yàn)檎f(shuō)實(shí)話(huà)我需要這兩周時(shí)間,以便將仿真用的測(cè)試臺(tái)準(zhǔn)備得停停當(dāng)當(dāng)。此項(xiàng)目采用VHDL編碼,而且我采取了一種循規(guī)蹈矩的方案保持層級(jí)結(jié)構(gòu),所有黑盒子(Black-box)、原語(yǔ)和宏指令都采用全局聲明(以便完成的設(shè)計(jì)仿真器并非萬(wàn)能 現(xiàn)在已經(jīng)到了關(guān)鍵時(shí)刻。我們已經(jīng)確定了電路板的設(shè)計(jì)原型,現(xiàn)正送回實(shí)驗(yàn)室進(jìn)行測(cè)試。由于后期規(guī)格更改,以及在
2、布線(xiàn)后信號(hào)完整性分析過(guò)程中發(fā)現(xiàn)的問(wèn)題,這個(gè)項(xiàng)目比原計(jì)劃滯后了兩周。這對(duì)我而言并非壞事,因?yàn)檎f(shuō)實(shí)話(huà)我需要這兩周時(shí)間,以便將仿真用的測(cè)試臺(tái)準(zhǔn)備得停停當(dāng)當(dāng)。 此項(xiàng)目采用 VHDL 編碼,而且我采取了一種循規(guī)蹈矩的方案保持層級(jí)結(jié)構(gòu),所有黑盒子 (Black-box)、原語(yǔ)和宏指令都采用全局聲明(以便完成的設(shè)計(jì)具有更高的可移植性并且可以符合 IEEE 標(biāo)準(zhǔn)),而且主要是一種 RTL 類(lèi)型的方案。當(dāng)然,我的部分設(shè)計(jì)具有行為屬性,要不然就是我完全忽略了 HDL 的主要優(yōu)勢(shì) 應(yīng)用行為抽象的能力。
3、0; 因此我多費(fèi)了點(diǎn)事,不過(guò)現(xiàn)在我可以開(kāi)始啟動(dòng)仿真工作了。仿真進(jìn)行了數(shù)毫秒,我對(duì)結(jié)果相當(dāng)滿(mǎn)意。我可以通過(guò) Wave 編輯器測(cè)量占空比與周期得到了我希望的結(jié)果,復(fù)位邏輯按照我所預(yù)測(cè)的時(shí)鐘周期數(shù)出現(xiàn),時(shí)鐘合成器運(yùn)行正確無(wú)誤。而且I/O 信號(hào)顯示出我所希望的 1、0 以及三態(tài)。值得一提的是,我很清楚地記得我在幾千行代碼中,已經(jīng)謹(jǐn)慎地避免了異步過(guò)程和時(shí)鐘域交叉,最重要的是解決信號(hào) (Resolved signal)。我想起學(xué)科導(dǎo)師曾經(jīng)略帶諷刺地說(shuō)PCB與芯片設(shè)計(jì)師才用三態(tài)。 開(kāi)始時(shí)的信心百倍讓我想冒點(diǎn)險(xiǎn),我決定將設(shè)計(jì)綜合在一起。幸運(yùn)的是,我使
4、用的工具允許我輕松嘗試多種不同綜合引擎,因此我開(kāi)始從其中一個(gè)內(nèi)置引擎入手。因?yàn)轫?xiàng)目中采用了幾種復(fù)雜的行為狀態(tài)機(jī),需要花點(diǎn)時(shí)間進(jìn)行優(yōu)化,不過(guò)完成時(shí)出現(xiàn)了少數(shù)幾個(gè)次要警告。到目前為止一切順利。 我的信心更足了一點(diǎn),接著繼續(xù)點(diǎn)擊“創(chuàng)建 (Build)”按鈕,接下來(lái)工作流程的“映射 (Map)”、“轉(zhuǎn)換 (Translate)”、“布局布線(xiàn) (Place and Route)”以及“位文件生成 (Bit File Generation)”,這些操作全部通過(guò)與芯片廠(chǎng)商工具的命令行接口在后臺(tái)執(zhí)行。映射設(shè)計(jì)進(jìn)行了大約一分半就停止了,顯示出一條有關(guān)
5、IBUFT 與 OBUFT 的難懂信息。唉!我知道自己的好日子到頭了,真是大夢(mèng)初醒??! 我接下來(lái)通常會(huì)聳聳肩膀,然后切換到 FPGA 廠(chǎng)商的綜合器,看看其優(yōu)化器能否產(chǎn)生可以順利布局與布線(xiàn)的結(jié)果。因此,點(diǎn)擊幾下鼠標(biāo)之后我開(kāi)始重新運(yùn)行 “綜合(Synthesis)”與“創(chuàng)建(Build)”。這次我注意到綜合多少比以前快了一點(diǎn)。我心中燃起希望,因?yàn)閺S(chǎng)商的引擎在進(jìn)行較少程度的優(yōu)化,而且將產(chǎn)生盡管更龐大、但更精確的實(shí)施方案。然后在映射過(guò)程中在同一地方嘎然而止,同樣出現(xiàn)了讓人費(fèi)解的錯(cuò)誤消息,然后是一條警告: ERROR:NgdBuild
6、: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 AND2B1WARNING:NgdBuild:465 - bidirect pad net 'DATA_IO<15>' has no legal load.
7、 我開(kāi)始嘟嘟囔囔,旁邊的同事瞇起眼睛,像老鷹山姆那樣斜眼著我。慶幸的是,我能夠從消息屏幕中的錯(cuò)誤消息中找到出現(xiàn)錯(cuò)誤的代碼行。雙擊與兩個(gè)串聯(lián)的緩沖區(qū)有關(guān)的第一個(gè)錯(cuò)誤消息后我找到了以下代碼片段:DATA_IO <= DATA_IN when CNTL_IN(4) = '0' - write to Ext. Device
8、; else (others => 'Z');DATA_OUT <= DATA_IO; - data from core to CF (5000_0050) 我最初的想法是“啊哈,我弄出了一個(gè)三態(tài)端口與多路復(fù)用器,多么好的想法呀?”。聰明而又經(jīng)驗(yàn)豐富的讀者一眼就能看清這個(gè)問(wèn)題,但是這種錯(cuò)誤會(huì)讓 FPGA 新手難倒好幾天,讓人寢食難安,心力憔悴。我盯著這三行代碼看了半分鐘,意識(shí)到應(yīng)該隨便找張紙畫(huà)出我最初的意圖: 現(xiàn)
9、在我認(rèn)識(shí)到,我之前認(rèn)為綜合引擎會(huì)明白我并不想在器件中加入高阻抗信號(hào)。實(shí)際上,當(dāng)我再次查看錯(cuò)誤與警告消息之后才清楚它就是這么干的: 如果您是一名出色的 FPGA 設(shè)計(jì)人員并且確實(shí)閱讀了數(shù)據(jù)手冊(cè)與程序庫(kù)指南,那么您立刻就會(huì)明白這是不可能的事情。我所知道的任何 FPGA 布線(xiàn)資源都不會(huì)允許這種連接。 我首先認(rèn)識(shí)到可以用原理圖當(dāng)畫(huà)出以下簡(jiǎn)單的 IOBUF 電路: 由于DATA_IO 與 DATA_OUT連接到較高層文檔中的 I
10、O 接口,綜合器會(huì)插入用于 DATA_OUT的適當(dāng) OBUF,因此我無(wú)需在此畫(huà)出。這個(gè)例子可以很好地說(shuō)明了原理圖與方框圖設(shè)計(jì)方案如何能實(shí)實(shí)在在地減少未知錯(cuò)誤。我的第二個(gè)更加驚人的發(fā)現(xiàn)是我在 VHDL 代碼中編寫(xiě)的內(nèi)容能夠全部得到正確仿真,這里顯示出了我實(shí)際預(yù)期的信號(hào)變化。當(dāng)然,我始終明白能夠仿真與能夠綜合之間的區(qū)別。這里有一個(gè)新的誤解 我可以無(wú)錯(cuò)地仿真并合成我的設(shè)計(jì)。我敢斷言,現(xiàn)在應(yīng)該被問(wèn):“它可以仿真,那么可以合成嗎?可以被映射嗎?” 這個(gè)場(chǎng)景是我虛構(gòu)的,盡管它出自我親身經(jīng)歷過(guò)的真實(shí)事件。我曾經(jīng)與許多喜歡在設(shè)計(jì)流程中使用 VHDL
11、和 Verilog 的 FPGA 設(shè)計(jì)人員深入探討過(guò)。我和他們有一致的看法,就是他們的大多數(shù)設(shè)計(jì)對(duì)于基于原理圖的方法來(lái)說(shuō)過(guò)于復(fù)雜。也就是說(shuō),您是否主要通過(guò) RTL 進(jìn)行設(shè)計(jì)。HDL 的發(fā)明可減少描繪邏輯函數(shù)的工作量,因?yàn)殚T(mén)電路與觸發(fā)電路的數(shù)量太多,也太繁復(fù)。然而, FPGA(和 ASIC)一直繼續(xù)遵循著摩爾定律。設(shè)計(jì)也是如此,復(fù)雜到使用VHDL 或 Verilog 設(shè)計(jì)會(huì)把你帶入泥潭,讓你再也看不清整體設(shè)計(jì)意圖。上面問(wèn)題就是例證。 設(shè)計(jì)人員需要保持他們?cè)O(shè)計(jì)的領(lǐng)先地位。我深信他們將別無(wú)選擇地這么做 采用更高端的方法來(lái)贏得時(shí)間和自由,從而可以集中精力進(jìn)行其產(chǎn)品最重要部分的設(shè)計(jì),即在市場(chǎng)上能使他們脫穎而出的部分。這個(gè)行業(yè)正在面臨的挑戰(zhàn)是:技能嫻熟的資深設(shè)計(jì)人員必須放下架子來(lái)使用與工具配套提供的免費(fèi)的IP,而不是自己親手通過(guò) H
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 公司繪畫(huà)體驗(yàn)活動(dòng)方案
- 公司百年活動(dòng)方案
- 公司游玩海邊活動(dòng)方案
- 公司溫泉游活動(dòng)策劃方案
- 公司管理部策劃方案
- 公司組織籃球活動(dòng)方案
- 公司棋類(lèi)活動(dòng)方案
- 公司歡聚日活動(dòng)策劃方案
- 公司旅游漂流活動(dòng)方案
- 公司模擬面試活動(dòng)方案
- 2024年天津市應(yīng)急管理局招聘行政執(zhí)法專(zhuān)職技術(shù)檢查員筆試真題
- 2025年養(yǎng)老護(hù)理員職業(yè)考試試題及答案
- 揭陽(yáng)惠來(lái)縣紀(jì)委監(jiān)委等部門(mén)屬下事業(yè)單位招聘筆試真題2024
- 春蘇教版六年級(jí)數(shù)學(xué)總復(fù)習(xí)30課時(shí)教學(xué)設(shè)計(jì)
- 黨課課件含講稿:以作風(fēng)建設(shè)新成效激發(fā)干事創(chuàng)業(yè)新作為
- 西安美術(shù)學(xué)院《舞臺(tái)編導(dǎo)藝術(shù)》2023-2024學(xué)年第二學(xué)期期末試卷
- 城投公司工程管理制度
- 2025全國(guó)農(nóng)業(yè)(水產(chǎn))行業(yè)職業(yè)技能大賽(水生物病害防治員)選拔賽試題庫(kù)(含答案)
- 油浸式變壓器 電抗器 檢修規(guī)范標(biāo)準(zhǔn)
- 2025年中國(guó)膨潤(rùn)土貓砂項(xiàng)目投資可行性研究報(bào)告
- 職業(yè)技術(shù)學(xué)院2024級(jí)智能機(jī)器人技術(shù)專(zhuān)業(yè)人才培養(yǎng)方案
評(píng)論
0/150
提交評(píng)論