《電子技術應用》
您所在的位置:首頁 > 可編程邏輯 > 解決方案 > 【Vivado使用誤區與進階】XDC約束技巧之時鐘篇

【Vivado使用誤區與進階】XDC約束技巧之時鐘篇

2015-03-05
關鍵詞: Vivado 約束 時鐘

Xilinx 的新一代設計套件Vivado中引入了全新的約束文件XDC,在很多規則和技巧上都跟上一代產品ISE中支持的UCF大不相同,給使用者帶來許多額外挑 戰。Xilinx工具專家告訴你,其實用好XDC很容易,只需掌握幾點核心技巧,并且時刻牢記:XDC的語法其實就是Tcl語言。

XDC的優勢

XDC 是Xilinx Design Constraints的簡寫,但其基礎語法來源于業界統一的約束規范SDC(最早由Synopsys公司提出,故名Synopsys Design Constraints)。所以SDC、XDC跟Vivado Tcl的關系如下圖所示。

XDC約束技巧之時鐘篇

XDC的主要優勢包括:

● 統一了前后端約束格式,便于管理;                          
● 可以像命令一樣實時錄入并執行;
● 允許增量設置約束,加速調試效率;
● 覆蓋率高,可擴展性好,效率高;
● 業界統一,兼容性好,可移植性強;

XDC在本質上就是Tcl語言,但其僅支持基本的Tcl語法如變量、列表和運算符等等,對其它復雜的循環以及文件I/O等語法可以通過在Vivado中source一個Tcl文件的方式來補充。(對Tcl話題感興趣的讀者可以參考作者的另一篇文章《Tcl在Vivado中的應用》

XDC與UCF的最主要區別有兩點:

1. XDC可以像UCF一樣作為一個整體文件被工具讀入,也可以在實現過程中被當作一個個單獨的命令直接執行。這就決定了XDC也具有Tcl命令的特點,即后 面輸入的約束在有沖突的情況下會覆蓋之前輸入的約束(時序例外的優先級會在下節詳述)。另外,不同于UCF是全部讀入再處理的方式,在XDC中,約束是讀 一條執行一條,所以先后順序很重要,例如要設置IO約束之前,相對應的clock一定要先創建好。

2. UCF是完全以FPGA的視角看問題,所以缺省認為所有的時鐘之間除非預先聲明是同步的,否則就視作異步而不做跨時鐘域時序分析;XDC則恰恰相 反,ASIC世界的血緣背景決定了在其中,所有的時鐘缺省視作全同步,在沒有時序例外的情況下,工具會主動分析每一條跨時鐘域的路徑。

XDC的基本語法

XDC 的基本語法可以分為時鐘約束、I/O約束以及時序例外約束三大類。根據Xilinx的UltraFast設計方法學中Baseline部分的建議 (UG949中有詳細介紹),對一個設計進行約束的先后順序也可以依照這三類約束依次進行。本文對可以在幫助文檔中查到的基本XDC語法不做詳細解釋,會 將重點放在使用方法和技巧上。

時鐘約束

時 鐘約束必須最早創建,對7系列FPGA來說,端口進來的主時鐘以及GT的輸出RXCLK/TXCLK都必須由用戶使用create_clock自主創建。 如果是差分輸入的時鐘,可以僅僅在差分對的P側用get_ports獲取端口,并使用create_clock創建。例如,

XDC約束技巧之時鐘篇

Vivado自動推導的衍生時鐘

MMCM/PLL /BUFR的輸出作為衍生時鐘,可以由Vivado自動推導,無需用戶創建。自動推導的好處在于當MMCM/PLL/BUFR的配置改變而影響到輸出時鐘 的頻率和相位時,用戶無需改寫約束,Vivado仍然可以自動推導出正確的頻率/相位信息。劣勢在于,用戶并不清楚自動推導出的衍生鐘的名字,當設計層次 改變時,衍生鐘的名字也有可能改變。這樣就會帶來一個問題:用戶需要使用這些衍生鐘的名字來創建I/O約束、時鐘關系或是時序例外等約束時,要么不知道時 鐘名字,要么時鐘名字是錯的。

推薦的做法是,由用戶來指定這類衍生時鐘的名字,其余頻率等都由Vivado 自動推導。這樣就只需寫明create_generated_clock 的三個option,其余不寫即可。如下所示。

XDC約束技巧之時鐘篇

當 然,此類情況下用戶也可以選擇完全由自己定義衍生時鐘,只需補上其余表示頻率/相位關系的option,包括-multiply_by 、-devide_by 等等。需要注意的是,一旦Vivado在MMCM/PLL/BUFR 的輸出檢測到用戶自定義的衍生時鐘,就會報告一個Warning,提醒用戶這個約束會覆蓋工具自動推導出的衍生時鐘(例外的情況見文章下半段重疊時鐘部分 的描述),用戶須保證自己創建的衍生鐘的頻率等屬性正確。

用戶自定義的衍生時鐘

工具不能自動推導出衍生鐘的情況,包括使用寄存器和組合邏輯搭建的分頻器等,必須由用戶使用create_generated_clock 來創建。舉例如下,

XDC約束技巧之時鐘篇

I/O約束

在設計的初級階段,可以不加I/O約束,讓工具專注于滿足FPGA內部的時序要求。當時序要求基本滿足后,再加上I/O約束跑實現。XDC中的I/O約束有以下幾點需要注意:

1. 不加任何I/O約束的端口時序要求被視作無窮大。

2. XDC中的set_input_delay / set_output_delay對應于UCF中OFFSET IN / OFFSET OUT,但視角相反。OFFSET IN / OFFSET OUT是從FPGA內部延時的角度來約束端口時序,set_input_delay / set_output_delay則是從系統角度來約束。

3. 典型的I/O時序,包括系統同步、源同步、SDR和DDR等等,在Vivado圖形界面的XDC templates中都有示例。2014.1版后還有一個Timing Constraints Wizard可供使用。

時序例外約束

時 序例外約束包括set_max_delay/set_min_delay,set_multicycle_path,set_false_path等,這 類約束除了要滿足XDC的先后順序優先級外,還受到自身優先級的限制。一個總的原則就是針對同一條路徑,對約束目標描述越具體的優先級越高。不同的時序例 外約束以及同一約束中不同條件的優先級如下所示:

XDC約束技巧之時鐘篇

舉例來說,依次執行如下兩條XDC,盡管第二條最后執行,但工具仍然認定第一條約束設定的15為clk1到clk2之間路徑的max delay值。

XDC約束技巧之時鐘篇

再比如,對圖示路徑依次進行如下四條時序例外約束,優勝者將是第二條。但如果再加入最后一條約束,false path的優先級最高,會取代之前所有的時序例外約束。

XDC約束技巧之時鐘篇

高級時鐘約束

約束最終是為了設計服務,所以要用好XDC就需要深入理解電路結構和設計需求。接下來我們就以常見FPGA設計中的時鐘結構來舉例,詳細闡述XDC的約束技巧。

時序的零起點

用 create_clock定義的主時鐘的起點即時序的"零起點",在這之前的上游路徑延時都被工具自動忽略。所以主時鐘創建在哪個"點"很重要,以下圖所 示結構來舉例,分別于FPGA輸入端口和BUFG輸出端口創建一個主時鐘,在時序報告中體現出的路徑延時完全不同,很明顯sysclk_bad的報告中缺 少了之前一段的延時,時序報告不可信。

XDC約束技巧之時鐘篇XDC約束技巧之時鐘篇

時鐘定義的先后順序

時鐘的定義也遵從XDC/Tcl的一般優先級,即:在同一個點上,由用戶定義的時鐘會覆蓋工具自動推導的時鐘,且后定義的時鐘會覆蓋先定義的時鐘。若要二者并存,必須使用 -add 選項。

XDC約束技巧之時鐘篇XDC約束技巧之時鐘篇

上 述例子中BUFG的輸出端由用戶自定義了一個衍生鐘clkbufg,這個衍生鐘便會覆蓋此處原有的sysclk。此外,圖示BUFR工作在bypass模 式,其輸出不會自動創建衍生鐘,但在BUFR的輸出端定義一個衍生鐘clkbufr,并使用-add 和 -master_clock 選項后,這一點上會存在sysclk和clkbufg兩個重疊的時鐘。如下的Tcl命令驗證了我們的推論。

XDC約束技巧之時鐘篇

同步時鐘和異步時鐘

XDC約束技巧之時鐘篇

不同于UCF約束,在XDC中,所有的時鐘都會被缺省認為是相關的,也就是說,網表中所有存在的時序路徑都會被Vivado分析。這也意味著FPGA設計人員必須通過約束告訴工具,哪些路徑是無需分析的,哪些時鐘域之間是異步的。

如上圖所示,兩個主時鐘ssclkin和sysclk由不同的端口進入FPGA,再經由不同的時鐘網絡傳遞,要將它們設成異步時鐘,可以使用如下約束:

XDC約束技巧之時鐘篇

其中,-include_generated_clocks 表示所有衍生鐘自動跟其主時鐘一組,從而與其它組的時鐘之間為異步關系。不加這個選項則僅僅將時鐘關系的約束應用在主時鐘層面。

重疊(單點多個)時鐘

重疊時鐘是指多個時鐘共享完全相同的時鐘傳輸網絡,例如兩個時鐘經過一個MUX選擇后輸出的時鐘,在有多種運行模式的設計中很常見。

如下圖所示,clk125和clk250是clkcore_buf的兩個輸入時鐘,不約束時鐘關系的情況下,Vivado會對圖示路徑做跨 時鐘域(重疊時鐘之間)分析。這樣的時序報告即便沒有違例,也是不可信的,因為clk125和clk250不可能同時驅動這條路徑上的時序元件。這么做也 會增加運行時間,并影響最終的實現效果。

XDC約束技巧之時鐘篇XDC約束技巧之時鐘篇

如果clk125和clk250除了通過clkcore_buf后一模一樣的扇出外沒有驅動其它時序元件,我們要做的僅僅是補齊時鐘關系的約束。

XDC約束技巧之時鐘篇

在 很多情況下,除了共同的扇出,其中一個時鐘或兩個都還驅動其它的時序元件,此時建議的做法是在clkcore_buf的輸出端上創建兩個重疊的衍生鐘,并 將其時鐘關系約束為-physically_exclusive 表示不可能同時通過。這樣做可以最大化約束覆蓋率,也是ISE和UCF中無法做到的。

XDC約束技巧之時鐘篇

其它高級約束

時鐘的約束是XDC的基礎,熟練掌握時鐘約束,也是XDC約束技巧的基礎。其它高級約束技巧,包括復雜的CDC(Clock Domain Crossing)約束和接口時序(SDR、DDR、系統同步接口和源同步接口)約束等方面還有很多值得注意的地方。

這一系列《XDC約束技巧》文章還會繼續就上述所列方向分篇詳述,敬請關注作者的后續更新,以及Xilinx 官方網站和中文論壇上的更多技術文章。

allyzhou.jpg

Ally Zhou 2014-9-25 于Xilinx上海Office


本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
国产精品丝袜91| 亚洲国产精品一区二区久| 麻豆国产精品一区二区三区| 欧美一级专区免费大片| 亚洲夜晚福利在线观看| 亚洲免费高清| 亚洲精选中文字幕| 亚洲精品乱码久久久久久蜜桃麻豆 | 亚洲你懂的在线视频| 亚洲午夜精品| 亚洲校园激情| 亚洲欧美日韩国产成人精品影院| 亚洲素人在线| 亚洲午夜精品久久久久久浪潮| 99精品国产高清一区二区| 亚洲免费av片| 一本高清dvd不卡在线观看| 一本色道久久综合狠狠躁的推荐| 日韩一级不卡| 亚洲视频欧美在线| 亚洲宅男天堂在线观看无病毒| 这里只有精品电影| 亚洲综合色噜噜狠狠| 欧美亚洲一级片| 久久成人免费电影| 久久午夜精品一区二区| 欧美成人午夜免费视在线看片| 欧美gay视频激情| 欧美激情中文字幕乱码免费| 欧美日韩一区综合| 国产精品区免费视频| 国产亚洲精品资源在线26u| 黑人极品videos精品欧美裸| 在线看片成人| 日韩视频在线一区二区| 一区二区三区日韩精品| 午夜精品999| 亚洲国产另类精品专区| 一区二区三区欧美日韩| 欧美一区二区三区男人的天堂| 久久久精品久久久久| 欧美顶级大胆免费视频| 欧美三日本三级少妇三99| 国产精品日韩精品欧美在线| 韩日欧美一区二区三区| 亚洲激情综合| 亚洲欧美国产日韩中文字幕| 久久精品国产综合精品| 99视频精品| 欧美在线观看视频一区二区三区| 看片网站欧美日韩| 欧美色图首页| 韩国久久久久| 99亚洲视频| 欧美一区二区在线免费观看| 亚洲精选大片| 欧美一区二区黄色| 欧美第十八页| 国产日韩精品在线播放| 亚洲国产欧美不卡在线观看| 亚洲午夜精品国产| 91久久嫩草影院一区二区| 亚洲欧美日韩另类| 免费日韩视频| 国产精品日韩二区| 亚洲精品国产精品国自产观看| 亚洲欧美另类国产| 99国产精品视频免费观看| 欧美在线观看日本一区| 欧美日韩成人| 国内精品免费午夜毛片| 夜夜爽夜夜爽精品视频| 久久精品国语| 欧美一区二区三区视频在线| 欧美久久视频| 一区视频在线播放| 亚洲免费一级电影| 在线午夜精品| 玖玖在线精品| 国产欧美日韩精品a在线观看| 亚洲三级免费| 亚洲国产精品一区二区www| 亚洲欧美国产日韩中文字幕| 欧美华人在线视频| 国产一区二区中文字幕免费看| 中文一区字幕| 夜夜嗨av一区二区三区四区| 麻豆91精品| 国产在线乱码一区二区三区| 亚洲午夜激情网站| 一区二区三区毛片| 欧美不卡在线| 国产揄拍国内精品对白| 亚洲永久免费视频| 在线视频欧美日韩精品| 欧美成人一区二区三区在线观看| 国产视频不卡| 亚洲一区二区在线看| 亚洲视屏在线播放| 欧美日韩精品免费观看| 亚洲国产一区二区三区在线播| 亚洲国产高潮在线观看| 久久精品欧美日韩| 国产精品人人做人人爽| 亚洲乱亚洲高清| 99日韩精品| 欧美剧在线观看| 在线播放国产一区中文字幕剧情欧美| 午夜精品在线| 久久国产乱子精品免费女| 国产精品日韩欧美一区二区三区| 日韩午夜三级在线| 一区二区三区日韩精品视频| 欧美精品亚洲精品| 亚洲国语精品自产拍在线观看| 亚洲国语精品自产拍在线观看| 久久手机精品视频| 好吊色欧美一区二区三区四区 | 亚洲女同在线| 午夜免费电影一区在线观看| 国产精品国产三级国产aⅴ浪潮| 亚洲作爱视频| 亚洲午夜高清视频| 国产精品久久久99| 亚洲午夜在线观看| 午夜精品国产| 国产欧美日韩视频一区二区三区| 午夜精品久久久久久久久| 欧美一区日本一区韩国一区| 国产欧美日韩精品丝袜高跟鞋| 午夜欧美大片免费观看| 久久精品一本久久99精品| 国产日韩欧美综合精品| 欧美专区第一页| 麻豆av一区二区三区| 激情久久久久久久| 亚洲激情国产| 欧美激情五月| 日韩一区二区精品葵司在线| 亚洲一区中文| 国产精品自在在线| 欧美亚洲三区| 久久亚洲综合色一区二区三区| 亚洲国产天堂久久综合| 一区二区三区四区五区在线 | 亚洲男人第一av网站| 久久精品国产在热久久| 韩日精品视频| 99re66热这里只有精品3直播| 欧美视频一区在线观看| 亚洲一区影音先锋| 久久久另类综合| 亚洲韩国一区二区三区| 亚洲一级在线观看| 国产女主播一区| 亚洲国产精品第一区二区| 欧美精品aa| 亚洲欧美成人一区二区三区| 老**午夜毛片一区二区三区| 亚洲精品国产精品国自产在线 | 久久精品国产一区二区电影 | 激情视频一区二区| 亚洲每日更新| 国产乱肥老妇国产一区二 | 欧美激情按摩在线| 亚洲少妇诱惑| 久久这里只有精品视频首页| 亚洲每日在线| 欧美在线观看网站| 亚洲国产精品久久久久久女王| 亚洲伊人网站| 黄色一区二区在线| 亚洲一区国产视频| 国产主播一区二区| 亚洲视频精品在线| 韩国女主播一区| 亚洲一区二区av电影| 国模私拍一区二区三区| 中文日韩电影网站| 韩国v欧美v日本v亚洲v| 亚洲午夜影视影院在线观看| 国内精品国语自产拍在线观看| 中文国产亚洲喷潮| 好吊视频一区二区三区四区| 亚洲在线播放| 亚洲高清资源| 久久国产精品久久久久久| 亚洲美女毛片| 麻豆精品91| 午夜久久资源| 欧美亚一区二区| 亚洲国产91精品在线观看| 国产精品国产三级国产专播精品人| 亚洲第一天堂无码专区| 国产精品免费一区二区三区观看| 亚洲精品久久久久久久久久久久| 国产区精品视频| 亚洲午夜精品视频| 亚洲国产欧美另类丝袜| 久久蜜桃精品|