《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 設計應用 > FPGA時序收斂
FPGA時序收斂
摘要: 您編寫的代碼是不是雖然在仿真器中表現(xiàn)正常,但是在現(xiàn)場卻斷斷續(xù)續(xù)出錯?要不然就是有可能在您使用更高版本的工具鏈進行編譯時,它開始出錯。您檢查自己的測試平臺,并確認測試已經(jīng)做到 100% 的完全覆蓋,而且所有測試均未出現(xiàn)任何差錯,但是問題仍然頑疾難除。
關鍵詞: FPGA 時序收斂 VHDL
Abstract:
Key words :

  您編寫的代碼是不是雖然在仿真器中表現(xiàn)正常,但是在現(xiàn)場卻斷斷續(xù)續(xù)出錯?要不然就是有可能在您使用更高版本的工具鏈進行編譯時,它開始出錯。您檢查自己的測試平臺,并確認測試已經(jīng)做到 100% 的完全覆蓋,而且所有測試均未出現(xiàn)任何差錯,但是問題仍然頑疾難除。

  雖然設計人員極其重視編碼和仿真,但是他們對芯片在 FGPA 中的內(nèi)部操作卻知之甚少,這是情有可原的。因此,不正確的邏輯綜合和時序問題(而非邏輯錯誤)成為大多數(shù)邏輯故障的根源。

  但是,只要設計人員措施得當,就能輕松編寫出能夠創(chuàng)建可預測、可靠邏輯的 FPGA 代碼。

  在 FPGA 設計過程中,需要在編譯階段進行邏輯綜合與相關時序收斂。而包括 I/O 單元結構、異步邏輯和時序約束等眾多方面,都會對編譯進程產(chǎn)生巨大影響,致使其每一輪都會在工具鏈中產(chǎn)生不同的結果。為了更好、更快地完成時序收斂,我們來進一步探討如何消除這些差異。

  I/O 單元結構

  所有 FPGA 都具有可實現(xiàn)高度定制的 I/O 引腳。定制會影響到時序、驅動強度、終端以及許多其它方面。如果您未明確定義 I/O 單元結構,則您的工具鏈往往會采用您預期或者不希望采用的默認結構。如下 VHDL 代碼的目的是采用“sda: inout std_logic;”聲明創(chuàng)建一個稱為 sda 的雙向 I/O 緩沖器。

程序

FPGA 編輯器視圖顯示了部分雙向I/O散布在I/O緩沖器之外

圖1 – FPGA 編輯器視圖顯示了部分雙向I/O散布在I/O緩沖器之外。

  當綜合工具發(fā)現(xiàn)這組代碼時,其中缺乏如何實施雙向緩沖器的明確指示。因此,工具會做出最合理的猜測。

  實現(xiàn)上述任務的一種方法是,在 FPGA 的 I/O 環(huán)上采用雙向緩沖器(事實上,這是一種理想的實施方式)。另一種選擇是采用三態(tài)輸出緩沖器和輸入緩沖器,二者都在查詢表 (LUT) 邏輯中實施。最后一種可行方法是,在 I/O 環(huán)上采用三態(tài)輸出緩沖器,同時在 LUT 中采用輸入緩沖器,這是大多數(shù)綜合器選用的方法。這三種方法都可以生成有效邏輯,但是后兩種實施方式會在I/O 引腳與 LUT 之間傳輸信號時產(chǎn)生更長的路由延遲。此外,它們還需要附加的時序約束,以確保時序收斂。FPGA 編輯器清晰表明:在圖 1 中,我們的雙向 I/O 有一部分散布在 I/O 緩沖器之外。

  教訓是切記不要讓綜合工具猜測如何實施代碼的關鍵部分。即使綜合后的邏輯碰巧達到您的預期,在綜合工具進入新版本時情況也有可能發(fā)生改變。應當明確定義您的 I/O 邏輯和所有關鍵邏輯。以下 VHDL 代碼顯示了如何采用 Xilinx® IOBUF 原語對 I/O 緩沖器進行隱含定義。另外需要注意的是,采用相似方式明確定義緩沖器的所有電氣特性。

程序

  在圖 2 中,F(xiàn)PGA 編輯器明確顯示,我們已完全在 I/O 緩沖器內(nèi)部實施了雙向 I/O。

  異步邏輯的劣勢

  異步代碼會產(chǎn)生難以約束、仿真及調(diào)試的邏輯。異步邏輯往往產(chǎn)生間歇性錯誤,而且這些錯誤幾乎無法重現(xiàn)。另外,無法生成用于檢測異步邏輯所導致的錯誤的測試平臺。

  雖然異步邏輯看起來可能容易檢測,但是,事實上它經(jīng)常不經(jīng)檢測;因此,設計人員必須小心異步邏輯在設計中隱藏的許多方面。所有鐘控邏輯都需要一個最短建立與保持時間,而且這一點同樣適用于觸發(fā)器的復位輸入。以下代碼采用異步復位。在此無法為了滿足觸發(fā)器的建立與保持時間需求而應用時序約束。

程序

  下列代碼采用同步復位。但是,大多數(shù)系統(tǒng)的復位信號都可能是按鍵開關,或是與系統(tǒng)時鐘無關的其它信號源。盡管復位信號大部分情況是靜態(tài)的,而且長期處于斷言或解除斷言狀態(tài),不過其水平仍然會有所變化。相當于系統(tǒng)時鐘上升沿,復位解除斷言可以違反觸發(fā)器的建立時間要求,而對此無法約束。

程序

  只要我們明白無法直接將異步信號饋送到我們的同步邏輯中,就很容易解決這個問題。以下代碼創(chuàng)建一個稱為 sys_reset 的新復位信號,其已經(jīng)與我們的系統(tǒng)時鐘 sys_clk 同步化。在異步邏輯采樣時會產(chǎn)生亞穩(wěn)定性問題。我們可以采用與階梯的前幾級進行了’與’運算的梯形采樣降低此問題的發(fā)生幾率。

程序

  至此,假定您已經(jīng)慎重實現(xiàn)了所有邏輯的同步化。不過,如果您不小心,則您的邏輯很容易與系統(tǒng)時鐘脫節(jié)。切勿讓您的工具鏈使用系統(tǒng)時鐘所用的本地布線資源。那樣做的話您就無法約束自己的邏輯。切記要明確定義所有的重要邏輯。

  以下 VHDL 代碼采用賽靈思 BUFG 原語強制 sys_clk 進入驅動低延遲網(wǎng)絡 (low-skew net) 的專用高扇出緩沖器。

程序

 

 

  某些設計采用單個主時鐘的分割版本來處理反序列化數(shù)據(jù)。以下 VHDL 代碼(nibble_proc進程)舉例說明了按系統(tǒng)時鐘頻率的四分之一采集的數(shù)據(jù)。

程序

程序

  看起來好像一切都已經(jīng)同步化,但是 nibble_proc 采用乘積項 divide_by_4 對來自時鐘域sys_clk_bufg 的 nibble_wide_data 進行采樣。由于路由延遲,divde_by_4 與 sys_clk_bufg 之間并無明確的相位關系。將 divide_by_4 轉移到 BUFG 也于事無補,因為此進程會產(chǎn)生路由延遲。解決方法是將 nibble_proc 保持在 sys_clk_bufg 域,并且采用 divide_by_4 作為限定符,如下所示。

 

程序

  時序約束的重要性

  如果您希望自己的邏輯正確運行,則必須采用正確的時序約束。如果您已經(jīng)慎重確保代碼全部同步且注冊了全部 I/O,則這些步驟可以顯著簡化時序收斂。在采用上述代碼并且假定系統(tǒng)時鐘為100MHz 時,則只需四行代碼就可以輕松完成時序約束文件,如下所示:

程序

  請注意:賽靈思 FPGA 中 I/O 注冊邏輯的建立與保持時間具有很高的固定性,在一個封裝中切勿有太大更改。但是,我們?nèi)匀徊捎盟鼈儯饕米骺纱_保設計符合其系統(tǒng)參數(shù)的驗證步驟。

  三步簡單操作

  僅需遵循以下三步簡單操作,設計人員即可輕松實施可靠的代碼。

  • 切勿讓綜合工具猜測您的預期。采用賽靈思原語對所有 I/O 引腳和關鍵邏輯進行明確定義。確保定義 I/O 引腳的電氣特性;

  • 確保邏輯 100% 同步,并且讓所有邏輯參考主時鐘域;

  • 應用時序約束確保時序收斂。

  只要遵循上述三個步驟,您就能夠消除綜合與時序導致的差異。掃除這兩個主要障礙會讓您獲得具有 100% 可靠性的代碼。

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲精品欧美日韩| 久久久久久亚洲综合影院红桃| 在线亚洲伦理| 最新国产精品拍自在线播放| 黑人中文字幕一区二区三区| 国产日韩欧美三级| 国产精品美女久久久久久2018 | 亚洲欧美日韩人成在线播放| 亚洲色在线视频| 在线视频亚洲| 宅男在线国产精品| 亚洲图片欧美日产| 中文网丁香综合网| 亚洲字幕一区二区| 亚洲综合首页| 性欧美超级视频| 欧美在线精品免播放器视频| 欧美与欧洲交xxxx免费观看| 久久精品国产69国产精品亚洲| 欧美一区二区精品| 久久精品国产久精国产爱| 久久精品九九| 蜜臀av性久久久久蜜臀aⅴ| 欧美777四色影视在线| 欧美国内亚洲| 欧美另类在线观看| 国产精品h在线观看| 国产美女一区| 韩国成人福利片在线播放| 狠狠色香婷婷久久亚洲精品| 亚洲第一久久影院| 亚洲精品影视在线观看| 亚洲视频免费看| 亚洲欧美日韩天堂一区二区| 欧美专区在线播放| 91久久精品一区二区别| 夜夜爽www精品| 午夜精品视频| 久久婷婷麻豆| 欧美精品v国产精品v日韩精品| 欧美视频官网| 国产日韩欧美一区二区三区四区| 国内外成人免费激情在线视频网站| 亚洲第一在线视频| 一区二区三区.www| 欧美在线免费| 99视频有精品| 亚洲欧美日韩在线一区| 久久久久在线观看| 欧美日韩不卡一区| 国产乱码精品1区2区3区| 极品尤物久久久av免费看| 亚洲精品婷婷| 性欧美video另类hd性玩具| 亚洲黄色高清| 亚洲女同精品视频| 免费成年人欧美视频| 欧美午夜无遮挡| 国产一区在线看| 日韩亚洲视频| 久久精品国产99精品国产亚洲性色 | 欧美日韩系列| 国产欧美日韩亚洲| 亚洲全部视频| 新67194成人永久网站| 亚洲免费观看在线观看| 欧美一区国产一区| 欧美激情一区二区三区不卡| 国产伦精品一区二区| 亚洲国产一区二区三区高清| 亚洲一区久久久| 亚洲精品视频在线| 欧美在线一二三| 欧美日韩国产va另类| 国产一区二区三区在线观看视频| 亚洲片在线资源| 欧美一区二区三区四区在线观看 | 久久久91精品国产| 欧美日韩视频| 亚洲成在人线av| 香蕉久久久久久久av网站| 夜夜嗨av一区二区三区四季av | 国产精品视频999| 亚洲日韩视频| 亚洲国产精品一区二区www在线| 亚洲一区二区精品在线观看| 欧美成人黑人xx视频免费观看| 国产欧美日韩精品一区| 一本在线高清不卡dvd| 亚洲国产精品美女| 欧美一区免费视频| 欧美色欧美亚洲高清在线视频| 黑人一区二区| 欧美一区2区视频在线观看 | 国产精品永久| 夜夜嗨av一区二区三区| 亚洲片国产一区一级在线观看| 久久精品综合网| 国产精品爽爽ⅴa在线观看| 亚洲人永久免费| 亚洲欧洲日本在线| 久久综合久久综合久久综合| 国产一区欧美日韩| 亚洲欧美另类在线| 午夜精品一区二区三区在线播放 | 在线欧美日韩国产| 久久精品国产第一区二区三区| 香蕉久久夜色精品国产| 欧美三级免费| 99国产精品久久久久久久久久| 亚洲伦理精品| 欧美黄色aaaa| 亚洲国产欧美不卡在线观看| 亚洲国产综合视频在线观看| 久久九九久精品国产免费直播 | 久久成人一区| 久久精品国产v日韩v亚洲| 国产精品视区| 亚洲欧美日韩精品久久奇米色影视 | 亚洲国产精品久久久久秋霞不卡 | 99精品国产高清一区二区| 99国产一区| 欧美精选在线| 亚洲人屁股眼子交8| 99re6这里只有精品| 欧美另类视频| 在线视频日本亚洲性| 亚洲综合色视频| 国产伦精品一区二区三区四区免费 | 精品成人国产| 亚洲欧洲在线视频| 欧美精品18+| 日韩小视频在线观看| 亚洲一区二区少妇| 国产精品入口66mio| 午夜精品剧场| 久久躁狠狠躁夜夜爽| 亚洲国产成人精品女人久久久| 亚洲精品久久久久久下一站| 欧美成人一品| 亚洲精品三级| 午夜久久久久久久久久一区二区| 国产麻豆视频精品| 亚洲大胆女人| 欧美激情免费在线| 一区二区精品在线观看| 欧美一区二区三区免费看| 狠狠v欧美v日韩v亚洲ⅴ| 亚洲精品三级| 欧美日韩精品系列| 亚洲欧美视频一区二区三区| 久久久久久9| 亚洲人成久久| 午夜免费电影一区在线观看| 国产一区二区三区在线观看视频 | 一区二区三区 在线观看视频| 国产精品r级在线| 欧美一区二区三区视频在线观看| 麻豆精品在线视频| 99riav久久精品riav| 欧美一区久久| 亚洲国产欧美一区二区三区同亚洲| 亚洲视频在线视频| 国产中文一区二区| 一区二区三区视频在线观看| 国产精自产拍久久久久久| 亚洲国产一区二区三区在线播 | 亚洲人成精品久久久久| 小黄鸭精品密入口导航| 黄色日韩精品| 亚洲视频中文字幕| 国产在线国偷精品产拍免费yy| 日韩视频亚洲视频| 国产小视频国产精品| 亚洲免费观看视频| 国产美女精品一区二区三区 | 亚洲一区国产精品| 国产在线不卡| 亚洲午夜精品久久久久久app| 国内精品视频在线观看| 亚洲午夜小视频| 激情五月婷婷综合| 午夜欧美精品久久久久久久| 亚洲国产欧美一区| 欧美中文字幕在线观看| 亚洲免费观看高清在线观看| 久久久噜噜噜久久久| 一区二区三区高清在线| 免费一级欧美片在线播放| 亚洲欧美日韩爽爽影院| 欧美日韩精品| 亚洲啪啪91| 国内精品久久久久影院 日本资源| 亚洲午夜一二三区视频| 亚洲大胆av| 久久精品国产亚洲一区二区| 一区二区黄色| 欧美区一区二| 亚洲黄色尤物视频| 国产婷婷成人久久av免费高清|