新 “All Programmable”器件
發布時間:2012/4/26 10:16:16 訪問次數:904
賽靈思 預計,一旦客戶啟用 vivado 設計套件,就會立即體會到其相對于 ise 的優勢。
與同類競爭工具相比,vivado 設計套件的運行時間可縮短高達 4 倍,能夠顯著提升用戶的設計生產力。同時該設計套件純熟地運用了多種業界標準,諸如 system verilog、sdc(synopsys 設計約束)、c/c++/system c、arm amba axi-4互聯、互動 tcl(工具命令語言)腳本。vivado 設計套件的其它突出優勢包括為 vivado 的眾多報告和設計視圖提供全面的交叉探測功能、預計將于 2012 年推出的高級圖形化 ip 集成功能、首款得到 fpga 廠商全面支持的商用高層次綜合技術(c++ 到 hdl綜合)。
一個面向新一代可編程設計的設計工具
賽靈思早在 1997 年就推出了 ise 設計套件。ise套件采用了當時非常具有創新性的基于時序的布局布線引擎,這是1995 年 4 月賽靈思收購 neocad 獲得的。在其后 15 年的時間里,隨著 fpga 能夠執行日趨復雜的功能,賽靈思為 ise 套件增添了許多新技術,包括多語言綜合與仿真、ip 集成以及眾多編輯和測試實用功能,努力不斷從各個方面改進 ise 設計套件。feist 表示,賽靈思通過借鑒 ise 設計套件的所有經驗、注意事項和關鍵技術,并充分利用最新 eda 算法、工具和技術,才打造出了這一顛覆性的全新 vivado 設計套件。
vivado 設計套件將顯著提升當今設計的生產力,且能夠輕松實現升級擴展,應對20nm 芯片及更小工藝技術所帶來的容量和設計復雜性挑戰。在過去 15 年時間里,eda 技術取得了長足的發展。我們是從頭開始開發這套工具的,所以我們能夠在套件中采用最先進的 eda 技術和標準,讓其具有很強的前瞻性。
確定性的設計收斂
任何 fpga 廠商的集成設計套件的核心都是物理設計流程,包括綜合, 布局規劃、布局、布線、功耗和時序分析、優化和eco。有了vivado,賽靈思打造了一個最先進的設計實現流程,可以讓客戶更快地達到設計收斂的目標。
可擴展的數據模型架構
為減少迭代次數和總體設計時間,并提高整體生產力,賽靈思用一個單一的、共享的、可擴展的數據模型建立其設計實現流程,這種框架也常見于當今最先進的 asic 設計環境。feist 說:“這種共享、可擴展的數據模型可讓流程中的綜合、仿真、布局規劃、布局布線等所有步驟在內存數據模型上運行,故在流程中的每一步都可以進行調試和分析,這樣用戶就可在設計流程中盡早掌握關鍵設計指標的情況,比如時序、功耗、資源利用和布線擁塞等。而且這些指標的估測將在實現過程中隨著設計流程的推進而更趨于精確。”
具體來說,這種統一的數據模型使賽靈思能夠將其新型多維分析布局布線引擎與套件的 rtl 綜合引擎、新型多語言仿真引擎以及 ip 集成器 (ip integrator)、引腳編輯器 (pin editor)、布局規劃器 (floor planner)、芯片編輯器 (chip editor) 等功能緊密集成在一起。此外,該數據模型使賽靈思能夠為該工具套件配備全面的交叉探測功能,以便用戶跟蹤并交叉探測原理圖、時序報告、邏輯單元或其它視圖,直至 hdl 代碼中的給定問題。
feist說:“用戶現在可以對設計流程中的每一步進行分析,而且環環相扣。在綜合后的流程中,我們還提供時序、功耗、噪聲和資源利用分析功能。所以如果很早就發現時序或功耗不符合要求,我可以通過短時迭代,前瞻性地解決問題,而不必等到布局布線完成后多次執行長時間迭代來解決。”
feist 指出,這種可擴展數據模型提供的緊密集成功能還增強了按鍵式流程的效果,從而可滿足用戶對工具實現最大自動化,完成大部分工作的期望。feist 表示,這種模型還能夠滿足客戶對更高級的控制、更深入的分析以及掌控每個設計步驟進程的需要。
芯片規劃層次化,快速綜合
feist說, vivado為用戶提供了設計分區的功能, 可以分別處理綜合、執行、驗證的設計,使其可以在執行大型項目時,可以成立不同的團隊分頭設計。 同時,新的設計保存功能可以實現時序結果的復用,并且可以實現設計的部分可重配置。
vivado還包括一個全新的綜合引擎,旨在處理數以百萬計的邏輯單元。新的綜合引擎的關鍵是對system verilog的強大支持。“vivado的綜合引擎對system veriog語言可綜合子集的支持, 比市場上任何其他工具都更好” feist 說。 它的綜合速度是賽靈思ise design suite綜合工具xst的三倍,并支持“快速”模式,使得設計師迅速把握設計的面積和規模。另外,也讓他們調試問題的速度比之前采用rtl或門級原理圖快15倍。隨著越來越多的asic設計者轉向可編程平臺,賽靈思還在整個vivado設計流程中提升了了synopsys 設計約束 (sdc)。標準的使用開啟了一個新的自動化水平, 客戶現在可以訪問先進的eda工具產生約束、檢查跨時鐘域、形式驗證,甚至是利用像synopsys primetime那樣的工具進行靜態時序的分析。
多維度分析布局器
feist 解釋說,上一代 fpga 設計套件采用單維基于時序的布局布線引擎,通過模擬退火算法隨機確定工具應在什么地方布置邏輯單元。使用這類工具時,用戶先輸入時序,模擬退火算法根據時序先從隨機初始布局種子開始,然后在本地移動單元,“盡量”與時序要求吻合。feist 說:“在當時這種方法是可行的,因為設計規模非常小,邏輯單元是造成延遲的主要原因。但今天隨著設計的日趨復雜化和芯片工藝的進步,互聯和設計擁塞一躍成為延遲的主因。采用模擬退火算法的布局布線引擎對低于 100 萬門的 fpga 來說是完全可以勝任的,但對超過這個水平的設計,引擎便不堪重負。不僅僅有擁塞的原因,隨著設計的規模超過100萬門,設計的結果也開始變得更加不可預測。”
著眼于未來,賽靈思為 vivado 設計套件開發了新型多維分析布局引擎,其可與當代價值百萬美元的 asic布局布線工具中所采用的引擎相媲美。該新型引擎通過分析可以找到從根本上能夠最小化設計三維(時序、擁塞和走線長度)的解決方案。feist 表示:“vivado設計套件的算法從全局進行優化,同時實現了最佳時序、擁塞和走線長度,它對整個設計進行通盤考慮,不像模擬退火算法只著眼于局部調整。這樣該工具能夠迅速、決定性地完成上千萬門的布局布線,同時保持始終如一的高結果質量(見圖 1)。由于它能夠同時處理三大要素,也意味著可以減少重復運行流程的次數。”
圖:與其它 fpga 工具相比,vivado 設計套件能夠以更快的速度、更優異的質量完成各種規模的設計
為展現這種優勢,賽靈思在 ise設計套件和 vivado 設計套件中用按鍵式流程方式同時運行針對賽靈思 zynq-7000 epp 仿真平臺開發的原始 rtl,同時將每種工具指向賽靈思世界最大容量的 fpga 器件——采用堆疊硅片互聯技術的 virtex-7 2000t fpga。這樣 vivado 設計套件的布局布線引擎僅耗時 5 個小時就完成了 120 萬邏輯單元的布局,而 ise 設計套件則耗時長達 13 個小時(圖 )。而且采用 vivado 設計套件實現的設計擁塞明顯降低(設計中顯示為灰色和黃色的部分),器件占用面積較小,這說明總體走線長度縮短。vivado 設計套件實現方案還體現出更出色的內存編譯效率,僅用9gb就實現設計要求的內存,而 ise 設計套件則用了 16gb。
feist 表示:“從本質上來說, 你看到的就是 vivado 設計套件在滿足所有約束條件下,實現整個設計只需占用 3/4 的器件資源。這意味著用戶可以為自己的設計添加更多的邏輯功能和片上存儲器,甚至可以采用更小型的器件。”
圖 :vivado 設計套件的多維分析算法可創建專門針對最佳時序、擁塞和走線長度(而不僅僅只是針對最佳時序)優化的布局。
功耗優化和分析
當今時代,功耗是fpga設計中最關鍵的環節之一。因此,vivado設計套件的重點就是專注于利用先進的功耗優化技術,為用戶的設計提供更大的功耗降低優勢。“我們在技術上采用了目前在asic工具套件中可以見到的先進的時鐘門控制技術,通過該技術可以擁有設計邏輯分析的功能,同時消除不必要的翻轉”feist表示 “具體來說,新的技術側重于翻轉因子 ‘alpha’,它能夠降低30%的動態功耗”feist說,賽靈思去年在ise設計套件中開始應用該技術, 并一直沿用至今。 vivado將繼續加強這一技術的應用。
有了這一新的可擴展的數據共享模型,用戶可以在設計流程的每一個階段得到功耗的估值,從而可以在問題發展的前期就能預先進行分析,從而能夠在設計流程中,先行解決問題。
簡化工程變更單(eco)
增量流量讓快速處理小的設計更改成為可能,每次更改后只需重新實現設計的一小部分,使迭代速度更快。它們還能在每個增量變化之后實現性能的表現,從而無需多個設計迭代。為此,vivado設計套件還包括對一個流行的ise fpga編輯器工具的新的擴展,稱為vivado器件編輯器。feist說,在一個布局布線設計上使用vivado器件編輯器,設計師現在有能力去做移動單元,重新布線, 連接一個寄存器輸出作為調試管腳,修改dcm或者查找表(lut)的參數的工程變更單(eco)——在設計周期的后期,無需通過返回設計重新綜合和實現。他說,目前行業沒有任何其他fpga設計環境可以提供這種級別的靈活性。
基于業界標準而打造
四年半前,當賽靈思開始從頭打造vivado設計套件的時候,架構打造的首要任務,就是用標準的設計環境代替專有格式。致力于打造一個開放的環境,讓客戶能夠用 eda 工具和第三方 ip 進行擴展。例如,vivado 設計套件可支持 sdc(synopsys 設計約束)、arm amba axi 4 ip互聯標準、ip-xact ip封裝和交付標準,并且在新環境中提供了強大的互動 tcl 腳本功能。
流程自動化,非流程強制化
在 vivado 設計套件構建過程中,賽靈思工具團隊遵循這樣的原則“自動化設計方式,不強制設計方式”。feist 說:“不管用戶用 c、c++、systemc、vhdl、verilog、system verilog、matlab 還是 simulink 開始編程,也不管他們用的是我們的 ip 還是第三方的 ip,我們提供了一種實現所有流程自動化,幫助客戶提高生產力的方法。我們還充分考慮到我們的用戶的各種技能水平和偏好,既能滿足需要全按鍵式流程的客戶的要求,也能滿足在設計流程的每一步都進行分析的客戶的要求,甚至還能滿足那些認為用 gui 的是低手,喜歡用 tcl 以命令行或批處理模式完成全部設計流程的客戶的要求。用戶能夠根據自己的特定需求,選用套件功能。”
為進一步增強所有用戶的設計體驗,賽靈思在 vivado 設計套件中加入了某些奇妙的新功能,同時為深受客戶贊譽的 fpga 編輯器增加了芯片編輯器功能。
ip 封裝器、集成器和目錄
賽靈思的工具架構團隊把重點放在新套件專門的 ip 功能設計上,以便于 ip 的開發、集成與存檔。為此,賽靈思開發出了 ip 封裝器、ip 集成器和可擴展 ip 目錄三種全新的 ip 功能。
feist 表示:“今天很難找到不采用ip 的 ic 設計。我們采用業界標準,提供專門便于 ip 開發、集成和存檔/維護的工具,這都有助于我們生態系統合作伙伴中的 ip 廠商和客戶快速構建 ip,提高設計生產力。目前已有 20 多家廠商提供支持該最新套件的 ip。”
采用 ip 封裝器,賽靈思的客戶、賽靈思公司自己的 ip 開發人員和賽靈思生態環境合作伙伴可以在設計流程的任何階段將自己的部分設計或整個設計轉換為可重用的內核,這里的設計可以是 rtl、網表、布局后的網表甚至是布局布線后的網表。ip 封裝器可以創建 ip 的 ip-xact 描述,這樣用戶使用新型 ip 集成器就能方便地將 ip 集成到未來設計中。ip 封裝器在 xml 文件中設定了每個 ip 的數據。feist 說一旦 ip 封裝完成,用 ip 集成器功能就可以將 ip 集成到設計的其余部分。
feist 說:“ip 集成器可以讓客戶在互聯層面而非引腳層面將 ip 集成到自己的設計中。可以將 ip 逐個拖放到自己的設計圖(canvas)上,ip 集成器會自動提前檢查對應的接口是否兼容。如果兼容,就可以在內核間劃一條線,然后集成器會自動編寫連接所有引腳的具體 rtl。”
feist 表示:“這里的重點是可以取出已用 ip 集成器集成的四五個模塊的輸出,然后通過封裝器再封裝。這樣就成了一個其他人可以重新使用的 ip。這種 ip 不一定必須是 rtl,可以是布局后的網表,甚至可以是布局布線后的網表模塊。這樣可以進一步節省集成和驗證時間。”
第三大功能是可擴展 ip 目錄,它使用戶能夠用他們自己創建的 ip 以及賽靈思和第三方廠商許可的 ip 創建自己的標準 ip 庫。賽靈思按照 ip-xact 標準要求創建的該目錄能夠讓設計團隊乃至企業更好的組織自己的 ip,供整個機構共享使用。feist 稱賽靈思系統生成器 (system generator) 和 ip 集成器均已與vivado 可擴展 ip 目錄集成,故用戶可以輕松訪問編目 ip 并將其集成到自己的設計項目中。
vivado 產品營銷總監 ramine roane指出:“以前第三方 ip 廠商用 zip 文件交付的ip格式各異,而現在他們交付的 ip,不僅格式統一,可立即使用,而且還與 vivado 套件兼容。”
vivado hls 把 els帶入主流
可能 vivado 設計套件采用的眾多新技術中,最具有前瞻性的要數新的 vivado hls(高層次綜合)技術,這是賽靈思 2010 年收購 autoesl 后獲得的。在收購這項業界最佳技術之前,賽靈思對商用 esl 解決方案進行了廣泛評估。市場調研公司 bdti 的研究結果幫助賽靈思做出了收購決策(見 賽靈思中國通訊雜志第 36 期“bdti研究認證以dsp為核心的fpga設計的高層次綜合流程.pdf” )。
feist 表示:“vivado hls 全面覆蓋 c、c++、systemc,能夠進行浮點運算和任意精度浮點運算。這意味著只要用戶愿意,可以在算法開發環境而不是典型的硬件開發環境中使用該工具。這樣做的優點在于在這個層面開發的算法的驗證速度比在 rtl 級有數量級的提高。這就是說,既可以讓算法提速,又可以探索算法的可行性,并且能夠在架構級實現吞吐量、時延和功耗的權衡取舍。”
設計人員使用 vivado hls 工具可以通過各種方式執行各種功能。為了演示方便,feist 講解了用戶如何通過一個通用的流程進行 vivado hls 開發 ip 并將其集成到自己的設計當中。
在這個流程中,用戶先創建一個設計 c、c++ 或 systemc 表達式,以及一個用于描述期望的設計行為的 c 測試平臺。隨后用 gcc/g++或 visual c++ 仿真器驗證設計的系統行為。一旦行為設計運行良好,對應的測試臺的問題全部解決,就可以通過 vivado hls synthesis 運行設計,生成 rtl 設計,代碼可以是 verilog,也可以是 vhdl。有了 rtl 后,隨即可以執行設計的 verilog 或 vhdl 仿真,或使用工具的 c封裝器技術創建 systemc 版本。然后可以進行system c架構級仿真,進一步根據之前創建的 c 測試平臺,驗證設計的架構行為和功能。
設計固化后,就可以通過 vivado 設計套件的物理實現流程來運行設計,將設計編程到器件上,在硬件中運行和/或使用 ip 封裝器將設計轉為可重用的 ip。隨后使用 ip 集成器將 ip 集成到設計中,或在系統生成器 (system generator) 中運行 ip。
圖三 vivado hls 支持設計團隊直接從系統級開始他們的設計.
這只是使用該工具的方法之一。實際上在即將發行的賽靈思xcell雜志中,安捷倫的 nathan jachimiec 和賽靈思的 fernando marinez vallina 將介紹如何使用 vivado hls 技術(在 ise設計套件的流程中稱為 autoesl 技術)為安捷倫開發 udp 包引擎。
vivado 仿真器
除了 vivado hls,公司還為該套件新開發了一種同時支持 verilog 和 vhdl 的混合語言仿真器。feist 表示,只需要單擊鼠標,用戶就可以啟動行為仿真,然后從集成波形查看器中查看結果。通過采用最新性能優化的仿真內核,可加速行為級仿真速度,執行速度比賽靈思 ise 設計套件仿真器快三倍。采用硬件協仿真,門級仿真速度則可加快 100 倍。
2012供貨情況
之前賽靈思ise 設計套件針對不同類型設計者(邏輯,嵌入式, dsp和系統)所發行的四個版本, 賽靈思將推出vivado 設計套件的兩個版本。其中, vivado 基礎設計版本包括新型 ip 工具和vivado的綜合-比特流流程。而 vivado 系統版本則包括設計版本的所有工具、系統生成器和賽靈思的最新 vivado hls 工具。
vivado 設計套件 2012.1 版本目前已隨早期試用計劃推出。如需了解更多詳情,敬請聯系您所在地的賽靈思代表。2012.2 版本將于第二季度中期公開發布,今年晚些時候還將推出 webpack。目前支持服務尚未到期的 ise 設計套件用戶除了ise之外,將免費得到全新的 vivado 設計套件。
對使用 28nm 器件之前器件的用戶,賽靈思將繼續提供對 ise 設計套件的支持。
歷經四年的開發和一年的試用版本測試,賽靈思可編程顛覆之作 vivado 設計套件終于震撼登場,并通過其早期試用計劃開始向客戶隆重推出。新的工具套件面向未來十年 “all programmable”器件而精心打造, 致力于加速其設計生產力。
賽靈思市場營銷與公司戰略高級副總裁steve glaser表示:“在過去的幾年中,賽靈思把半導體技術的創新推向了一個新的高度,并釋放了可編程器件全面的系統級能力。隨著賽靈思在獲獎的zynq-7000 epp(可 擴展式處理平臺)器件、革命性的3d virtex-7堆疊硅片互聯(ssi)的技術器件上的部署,除了我們在fpga技術上的不斷創新之外, ,我們正開啟著一個令人興奮的新時代——一個“all programmable”器件的時代。”
“all programmable”器件,將使設計團隊不僅能夠為他們的設計編程定制邏輯,而且也可以基于arm®和賽靈思處理子系統、算法和i / o進行編程。總之,這是一個全面的系統級的器件。steve glaser說“未來“all programmable”器件要比可編程邏輯設計更多。他們將是可編程的系統集成,投入的芯片越來越少,而集成的系統功能卻越來越多。”
steve glaser還表示,在利用“all programmable”器件創建系統的時候,設計者所面臨的是一套全新的集成和實現設計生產力的瓶頸問題。一方面從集成的角度講,其中包括集成算法c和寄存器傳輸級(rtl)的ip;混合了dsp、嵌入式、連接和邏輯域;驗證模塊和“系統”,以及設計和ip的重用等。實現的瓶頸包括芯片規劃和分層;多領域和大量的物理優化;多元的“設計”與“時序”收斂;和后期的eco和設計變更的連鎖效應。
正是為了解決集成和實現的瓶頸,使用戶能夠充分利用這些“all programmable”器件的系統集成能力,賽靈思打造了全新vivado設計套件。
在vivado 設計套件這一以系統為中心的工具套件的開發過程中,賽靈思以業界標準為標桿并采用了先進的 eda 技術與方法。為此,無論是需要高度自動化按鍵式流程的客戶,還是需要實際操作性極強的可修改流程的客戶,他們現在能夠比以往更快更高效地進行設計(甚至包括賽靈思最大型的 fpga 設計),同時還是在一個熟悉而直觀的先進的 eda 環境下工作。
賽靈思開發 vivado 設計套件的目的是為客戶提供一種具有完整系統可編程功能的新型工具套件,該套件遠遠超越了賽靈思為時甚久的旗艦型 ise 設計套件。為幫助客戶順利過渡到vivado 設計套件的使用,賽靈思將繼續堅定地為采用 7 系列及更早期的賽靈思 fpga 技術的客戶提供 ise 支持。今后 vivado 設計套件將成為賽靈思的旗艦設計環境,支持所有 7 系列器件及賽靈思未來器件。
深圳市鑫科電子有限公司
賽靈思 預計,一旦客戶啟用 vivado 設計套件,就會立即體會到其相對于 ise 的優勢。
與同類競爭工具相比,vivado 設計套件的運行時間可縮短高達 4 倍,能夠顯著提升用戶的設計生產力。同時該設計套件純熟地運用了多種業界標準,諸如 system verilog、sdc(synopsys 設計約束)、c/c++/system c、arm amba axi-4互聯、互動 tcl(工具命令語言)腳本。vivado 設計套件的其它突出優勢包括為 vivado 的眾多報告和設計視圖提供全面的交叉探測功能、預計將于 2012 年推出的高級圖形化 ip 集成功能、首款得到 fpga 廠商全面支持的商用高層次綜合技術(c++ 到 hdl綜合)。
一個面向新一代可編程設計的設計工具
賽靈思早在 1997 年就推出了 ise 設計套件。ise套件采用了當時非常具有創新性的基于時序的布局布線引擎,這是1995 年 4 月賽靈思收購 neocad 獲得的。在其后 15 年的時間里,隨著 fpga 能夠執行日趨復雜的功能,賽靈思為 ise 套件增添了許多新技術,包括多語言綜合與仿真、ip 集成以及眾多編輯和測試實用功能,努力不斷從各個方面改進 ise 設計套件。feist 表示,賽靈思通過借鑒 ise 設計套件的所有經驗、注意事項和關鍵技術,并充分利用最新 eda 算法、工具和技術,才打造出了這一顛覆性的全新 vivado 設計套件。
vivado 設計套件將顯著提升當今設計的生產力,且能夠輕松實現升級擴展,應對20nm 芯片及更小工藝技術所帶來的容量和設計復雜性挑戰。在過去 15 年時間里,eda 技術取得了長足的發展。我們是從頭開始開發這套工具的,所以我們能夠在套件中采用最先進的 eda 技術和標準,讓其具有很強的前瞻性。
確定性的設計收斂
任何 fpga 廠商的集成設計套件的核心都是物理設計流程,包括綜合, 布局規劃、布局、布線、功耗和時序分析、優化和eco。有了vivado,賽靈思打造了一個最先進的設計實現流程,可以讓客戶更快地達到設計收斂的目標。
可擴展的數據模型架構
為減少迭代次數和總體設計時間,并提高整體生產力,賽靈思用一個單一的、共享的、可擴展的數據模型建立其設計實現流程,這種框架也常見于當今最先進的 asic 設計環境。feist 說:“這種共享、可擴展的數據模型可讓流程中的綜合、仿真、布局規劃、布局布線等所有步驟在內存數據模型上運行,故在流程中的每一步都可以進行調試和分析,這樣用戶就可在設計流程中盡早掌握關鍵設計指標的情況,比如時序、功耗、資源利用和布線擁塞等。而且這些指標的估測將在實現過程中隨著設計流程的推進而更趨于精確。”
具體來說,這種統一的數據模型使賽靈思能夠將其新型多維分析布局布線引擎與套件的 rtl 綜合引擎、新型多語言仿真引擎以及 ip 集成器 (ip integrator)、引腳編輯器 (pin editor)、布局規劃器 (floor planner)、芯片編輯器 (chip editor) 等功能緊密集成在一起。此外,該數據模型使賽靈思能夠為該工具套件配備全面的交叉探測功能,以便用戶跟蹤并交叉探測原理圖、時序報告、邏輯單元或其它視圖,直至 hdl 代碼中的給定問題。
feist說:“用戶現在可以對設計流程中的每一步進行分析,而且環環相扣。在綜合后的流程中,我們還提供時序、功耗、噪聲和資源利用分析功能。所以如果很早就發現時序或功耗不符合要求,我可以通過短時迭代,前瞻性地解決問題,而不必等到布局布線完成后多次執行長時間迭代來解決。”
feist 指出,這種可擴展數據模型提供的緊密集成功能還增強了按鍵式流程的效果,從而可滿足用戶對工具實現最大自動化,完成大部分工作的期望。feist 表示,這種模型還能夠滿足客戶對更高級的控制、更深入的分析以及掌控每個設計步驟進程的需要。
芯片規劃層次化,快速綜合
feist說, vivado為用戶提供了設計分區的功能, 可以分別處理綜合、執行、驗證的設計,使其可以在執行大型項目時,可以成立不同的團隊分頭設計。 同時,新的設計保存功能可以實現時序結果的復用,并且可以實現設計的部分可重配置。
vivado還包括一個全新的綜合引擎,旨在處理數以百萬計的邏輯單元。新的綜合引擎的關鍵是對system verilog的強大支持。“vivado的綜合引擎對system veriog語言可綜合子集的支持, 比市場上任何其他工具都更好” feist 說。 它的綜合速度是賽靈思ise design suite綜合工具xst的三倍,并支持“快速”模式,使得設計師迅速把握設計的面積和規模。另外,也讓他們調試問題的速度比之前采用rtl或門級原理圖快15倍。隨著越來越多的asic設計者轉向可編程平臺,賽靈思還在整個vivado設計流程中提升了了synopsys 設計約束 (sdc)。標準的使用開啟了一個新的自動化水平, 客戶現在可以訪問先進的eda工具產生約束、檢查跨時鐘域、形式驗證,甚至是利用像synopsys primetime那樣的工具進行靜態時序的分析。
多維度分析布局器
feist 解釋說,上一代 fpga 設計套件采用單維基于時序的布局布線引擎,通過模擬退火算法隨機確定工具應在什么地方布置邏輯單元。使用這類工具時,用戶先輸入時序,模擬退火算法根據時序先從隨機初始布局種子開始,然后在本地移動單元,“盡量”與時序要求吻合。feist 說:“在當時這種方法是可行的,因為設計規模非常小,邏輯單元是造成延遲的主要原因。但今天隨著設計的日趨復雜化和芯片工藝的進步,互聯和設計擁塞一躍成為延遲的主因。采用模擬退火算法的布局布線引擎對低于 100 萬門的 fpga 來說是完全可以勝任的,但對超過這個水平的設計,引擎便不堪重負。不僅僅有擁塞的原因,隨著設計的規模超過100萬門,設計的結果也開始變得更加不可預測。”
著眼于未來,賽靈思為 vivado 設計套件開發了新型多維分析布局引擎,其可與當代價值百萬美元的 asic布局布線工具中所采用的引擎相媲美。該新型引擎通過分析可以找到從根本上能夠最小化設計三維(時序、擁塞和走線長度)的解決方案。feist 表示:“vivado設計套件的算法從全局進行優化,同時實現了最佳時序、擁塞和走線長度,它對整個設計進行通盤考慮,不像模擬退火算法只著眼于局部調整。這樣該工具能夠迅速、決定性地完成上千萬門的布局布線,同時保持始終如一的高結果質量(見圖 1)。由于它能夠同時處理三大要素,也意味著可以減少重復運行流程的次數。”
圖:與其它 fpga 工具相比,vivado 設計套件能夠以更快的速度、更優異的質量完成各種規模的設計
為展現這種優勢,賽靈思在 ise設計套件和 vivado 設計套件中用按鍵式流程方式同時運行針對賽靈思 zynq-7000 epp 仿真平臺開發的原始 rtl,同時將每種工具指向賽靈思世界最大容量的 fpga 器件——采用堆疊硅片互聯技術的 virtex-7 2000t fpga。這樣 vivado 設計套件的布局布線引擎僅耗時 5 個小時就完成了 120 萬邏輯單元的布局,而 ise 設計套件則耗時長達 13 個小時(圖 )。而且采用 vivado 設計套件實現的設計擁塞明顯降低(設計中顯示為灰色和黃色的部分),器件占用面積較小,這說明總體走線長度縮短。vivado 設計套件實現方案還體現出更出色的內存編譯效率,僅用9gb就實現設計要求的內存,而 ise 設計套件則用了 16gb。
feist 表示:“從本質上來說, 你看到的就是 vivado 設計套件在滿足所有約束條件下,實現整個設計只需占用 3/4 的器件資源。這意味著用戶可以為自己的設計添加更多的邏輯功能和片上存儲器,甚至可以采用更小型的器件。”
圖 :vivado 設計套件的多維分析算法可創建專門針對最佳時序、擁塞和走線長度(而不僅僅只是針對最佳時序)優化的布局。
功耗優化和分析
當今時代,功耗是fpga設計中最關鍵的環節之一。因此,vivado設計套件的重點就是專注于利用先進的功耗優化技術,為用戶的設計提供更大的功耗降低優勢。“我們在技術上采用了目前在asic工具套件中可以見到的先進的時鐘門控制技術,通過該技術可以擁有設計邏輯分析的功能,同時消除不必要的翻轉”feist表示 “具體來說,新的技術側重于翻轉因子 ‘alpha’,它能夠降低30%的動態功耗”feist說,賽靈思去年在ise設計套件中開始應用該技術, 并一直沿用至今。 vivado將繼續加強這一技術的應用。
有了這一新的可擴展的數據共享模型,用戶可以在設計流程的每一個階段得到功耗的估值,從而可以在問題發展的前期就能預先進行分析,從而能夠在設計流程中,先行解決問題。
簡化工程變更單(eco)
增量流量讓快速處理小的設計更改成為可能,每次更改后只需重新實現設計的一小部分,使迭代速度更快。它們還能在每個增量變化之后實現性能的表現,從而無需多個設計迭代。為此,vivado設計套件還包括對一個流行的ise fpga編輯器工具的新的擴展,稱為vivado器件編輯器。feist說,在一個布局布線設計上使用vivado器件編輯器,設計師現在有能力去做移動單元,重新布線, 連接一個寄存器輸出作為調試管腳,修改dcm或者查找表(lut)的參數的工程變更單(eco)——在設計周期的后期,無需通過返回設計重新綜合和實現。他說,目前行業沒有任何其他fpga設計環境可以提供這種級別的靈活性。
基于業界標準而打造
四年半前,當賽靈思開始從頭打造vivado設計套件的時候,架構打造的首要任務,就是用標準的設計環境代替專有格式。致力于打造一個開放的環境,讓客戶能夠用 eda 工具和第三方 ip 進行擴展。例如,vivado 設計套件可支持 sdc(synopsys 設計約束)、arm amba axi 4 ip互聯標準、ip-xact ip封裝和交付標準,并且在新環境中提供了強大的互動 tcl 腳本功能。
流程自動化,非流程強制化
在 vivado 設計套件構建過程中,賽靈思工具團隊遵循這樣的原則“自動化設計方式,不強制設計方式”。feist 說:“不管用戶用 c、c++、systemc、vhdl、verilog、system verilog、matlab 還是 simulink 開始編程,也不管他們用的是我們的 ip 還是第三方的 ip,我們提供了一種實現所有流程自動化,幫助客戶提高生產力的方法。我們還充分考慮到我們的用戶的各種技能水平和偏好,既能滿足需要全按鍵式流程的客戶的要求,也能滿足在設計流程的每一步都進行分析的客戶的要求,甚至還能滿足那些認為用 gui 的是低手,喜歡用 tcl 以命令行或批處理模式完成全部設計流程的客戶的要求。用戶能夠根據自己的特定需求,選用套件功能。”
為進一步增強所有用戶的設計體驗,賽靈思在 vivado 設計套件中加入了某些奇妙的新功能,同時為深受客戶贊譽的 fpga 編輯器增加了芯片編輯器功能。
ip 封裝器、集成器和目錄
賽靈思的工具架構團隊把重點放在新套件專門的 ip 功能設計上,以便于 ip 的開發、集成與存檔。為此,賽靈思開發出了 ip 封裝器、ip 集成器和可擴展 ip 目錄三種全新的 ip 功能。
feist 表示:“今天很難找到不采用ip 的 ic 設計。我們采用業界標準,提供專門便于 ip 開發、集成和存檔/維護的工具,這都有助于我們生態系統合作伙伴中的 ip 廠商和客戶快速構建 ip,提高設計生產力。目前已有 20 多家廠商提供支持該最新套件的 ip。”
采用 ip 封裝器,賽靈思的客戶、賽靈思公司自己的 ip 開發人員和賽靈思生態環境合作伙伴可以在設計流程的任何階段將自己的部分設計或整個設計轉換為可重用的內核,這里的設計可以是 rtl、網表、布局后的網表甚至是布局布線后的網表。ip 封裝器可以創建 ip 的 ip-xact 描述,這樣用戶使用新型 ip 集成器就能方便地將 ip 集成到未來設計中。ip 封裝器在 xml 文件中設定了每個 ip 的數據。feist 說一旦 ip 封裝完成,用 ip 集成器功能就可以將 ip 集成到設計的其余部分。
feist 說:“ip 集成器可以讓客戶在互聯層面而非引腳層面將 ip 集成到自己的設計中。可以將 ip 逐個拖放到自己的設計圖(canvas)上,ip 集成器會自動提前檢查對應的接口是否兼容。如果兼容,就可以在內核間劃一條線,然后集成器會自動編寫連接所有引腳的具體 rtl。”
feist 表示:“這里的重點是可以取出已用 ip 集成器集成的四五個模塊的輸出,然后通過封裝器再封裝。這樣就成了一個其他人可以重新使用的 ip。這種 ip 不一定必須是 rtl,可以是布局后的網表,甚至可以是布局布線后的網表模塊。這樣可以進一步節省集成和驗證時間。”
第三大功能是可擴展 ip 目錄,它使用戶能夠用他們自己創建的 ip 以及賽靈思和第三方廠商許可的 ip 創建自己的標準 ip 庫。賽靈思按照 ip-xact 標準要求創建的該目錄能夠讓設計團隊乃至企業更好的組織自己的 ip,供整個機構共享使用。feist 稱賽靈思系統生成器 (system generator) 和 ip 集成器均已與vivado 可擴展 ip 目錄集成,故用戶可以輕松訪問編目 ip 并將其集成到自己的設計項目中。
vivado 產品營銷總監 ramine roane指出:“以前第三方 ip 廠商用 zip 文件交付的ip格式各異,而現在他們交付的 ip,不僅格式統一,可立即使用,而且還與 vivado 套件兼容。”
vivado hls 把 els帶入主流
可能 vivado 設計套件采用的眾多新技術中,最具有前瞻性的要數新的 vivado hls(高層次綜合)技術,這是賽靈思 2010 年收購 autoesl 后獲得的。在收購這項業界最佳技術之前,賽靈思對商用 esl 解決方案進行了廣泛評估。市場調研公司 bdti 的研究結果幫助賽靈思做出了收購決策(見 賽靈思中國通訊雜志第 36 期“bdti研究認證以dsp為核心的fpga設計的高層次綜合流程.pdf” )。
feist 表示:“vivado hls 全面覆蓋 c、c++、systemc,能夠進行浮點運算和任意精度浮點運算。這意味著只要用戶愿意,可以在算法開發環境而不是典型的硬件開發環境中使用該工具。這樣做的優點在于在這個層面開發的算法的驗證速度比在 rtl 級有數量級的提高。這就是說,既可以讓算法提速,又可以探索算法的可行性,并且能夠在架構級實現吞吐量、時延和功耗的權衡取舍。”
設計人員使用 vivado hls 工具可以通過各種方式執行各種功能。為了演示方便,feist 講解了用戶如何通過一個通用的流程進行 vivado hls 開發 ip 并將其集成到自己的設計當中。
在這個流程中,用戶先創建一個設計 c、c++ 或 systemc 表達式,以及一個用于描述期望的設計行為的 c 測試平臺。隨后用 gcc/g++或 visual c++ 仿真器驗證設計的系統行為。一旦行為設計運行良好,對應的測試臺的問題全部解決,就可以通過 vivado hls synthesis 運行設計,生成 rtl 設計,代碼可以是 verilog,也可以是 vhdl。有了 rtl 后,隨即可以執行設計的 verilog 或 vhdl 仿真,或使用工具的 c封裝器技術創建 systemc 版本。然后可以進行system c架構級仿真,進一步根據之前創建的 c 測試平臺,驗證設計的架構行為和功能。
設計固化后,就可以通過 vivado 設計套件的物理實現流程來運行設計,將設計編程到器件上,在硬件中運行和/或使用 ip 封裝器將設計轉為可重用的 ip。隨后使用 ip 集成器將 ip 集成到設計中,或在系統生成器 (system generator) 中運行 ip。
圖三 vivado hls 支持設計團隊直接從系統級開始他們的設計.
這只是使用該工具的方法之一。實際上在即將發行的賽靈思xcell雜志中,安捷倫的 nathan jachimiec 和賽靈思的 fernando marinez vallina 將介紹如何使用 vivado hls 技術(在 ise設計套件的流程中稱為 autoesl 技術)為安捷倫開發 udp 包引擎。
vivado 仿真器
除了 vivado hls,公司還為該套件新開發了一種同時支持 verilog 和 vhdl 的混合語言仿真器。feist 表示,只需要單擊鼠標,用戶就可以啟動行為仿真,然后從集成波形查看器中查看結果。通過采用最新性能優化的仿真內核,可加速行為級仿真速度,執行速度比賽靈思 ise 設計套件仿真器快三倍。采用硬件協仿真,門級仿真速度則可加快 100 倍。
2012供貨情況
之前賽靈思ise 設計套件針對不同類型設計者(邏輯,嵌入式, dsp和系統)所發行的四個版本, 賽靈思將推出vivado 設計套件的兩個版本。其中, vivado 基礎設計版本包括新型 ip 工具和vivado的綜合-比特流流程。而 vivado 系統版本則包括設計版本的所有工具、系統生成器和賽靈思的最新 vivado hls 工具。
vivado 設計套件 2012.1 版本目前已隨早期試用計劃推出。如需了解更多詳情,敬請聯系您所在地的賽靈思代表。2012.2 版本將于第二季度中期公開發布,今年晚些時候還將推出 webpack。目前支持服務尚未到期的 ise 設計套件用戶除了ise之外,將免費得到全新的 vivado 設計套件。
對使用 28nm 器件之前器件的用戶,賽靈思將繼續提供對 ise 設計套件的支持。
歷經四年的開發和一年的試用版本測試,賽靈思可編程顛覆之作 vivado 設計套件終于震撼登場,并通過其早期試用計劃開始向客戶隆重推出。新的工具套件面向未來十年 “all programmable”器件而精心打造, 致力于加速其設計生產力。
賽靈思市場營銷與公司戰略高級副總裁steve glaser表示:“在過去的幾年中,賽靈思把半導體技術的創新推向了一個新的高度,并釋放了可編程器件全面的系統級能力。隨著賽靈思在獲獎的zynq-7000 epp(可 擴展式處理平臺)器件、革命性的3d virtex-7堆疊硅片互聯(ssi)的技術器件上的部署,除了我們在fpga技術上的不斷創新之外, ,我們正開啟著一個令人興奮的新時代——一個“all programmable”器件的時代。”
“all programmable”器件,將使設計團隊不僅能夠為他們的設計編程定制邏輯,而且也可以基于arm®和賽靈思處理子系統、算法和i / o進行編程。總之,這是一個全面的系統級的器件。steve glaser說“未來“all programmable”器件要比可編程邏輯設計更多。他們將是可編程的系統集成,投入的芯片越來越少,而集成的系統功能卻越來越多。”
steve glaser還表示,在利用“all programmable”器件創建系統的時候,設計者所面臨的是一套全新的集成和實現設計生產力的瓶頸問題。一方面從集成的角度講,其中包括集成算法c和寄存器傳輸級(rtl)的ip;混合了dsp、嵌入式、連接和邏輯域;驗證模塊和“系統”,以及設計和ip的重用等。實現的瓶頸包括芯片規劃和分層;多領域和大量的物理優化;多元的“設計”與“時序”收斂;和后期的eco和設計變更的連鎖效應。
正是為了解決集成和實現的瓶頸,使用戶能夠充分利用這些“all programmable”器件的系統集成能力,賽靈思打造了全新vivado設計套件。
在vivado 設計套件這一以系統為中心的工具套件的開發過程中,賽靈思以業界標準為標桿并采用了先進的 eda 技術與方法。為此,無論是需要高度自動化按鍵式流程的客戶,還是需要實際操作性極強的可修改流程的客戶,他們現在能夠比以往更快更高效地進行設計(甚至包括賽靈思最大型的 fpga 設計),同時還是在一個熟悉而直觀的先進的 eda 環境下工作。
賽靈思開發 vivado 設計套件的目的是為客戶提供一種具有完整系統可編程功能的新型工具套件,該套件遠遠超越了賽靈思為時甚久的旗艦型 ise 設計套件。為幫助客戶順利過渡到vivado 設計套件的使用,賽靈思將繼續堅定地為采用 7 系列及更早期的賽靈思 fpga 技術的客戶提供 ise 支持。今后 vivado 設計套件將成為賽靈思的旗艦設計環境,支持所有 7 系列器件及賽靈思未來器件。
深圳市鑫科電子有限公司
上一篇:科學家發明新型電子傳感器
下一篇:中國智能電網發展