應(yīng)用PlanAhead工具提高設(shè)計效率
設(shè)計問題尤其涉及到那些大型高性能計劃,最有效的解決方法就是首先對問題詳盡分析,然后將大問題分解成易于管理的小問題。觀察近年來可編程器件的發(fā)展過程,fpga在尺寸和復雜性方面有巨大的提高,但pld eda工具卻相對沒有多少變化。在傳統(tǒng)的扁平設(shè)計流程中,每個設(shè)計更改都意味著要對整個設(shè)計重新綜合、重新實現(xiàn)。對于要在幾百萬門的器件上實現(xiàn)的復雜設(shè)計來說,即使是一個微小的更改也會導致長時間的令人無法接受的布局布線(par),更不要說典型設(shè)計中從ptl 到par的反復操作所導致的時間耗費。
本文引用地址:http://www.ex-cimer.com/article/21024.htm很少有設(shè)計團隊能夠容忍超過預期時間設(shè)計仍得到出乎意料的低性能,更別說隨之而來的挫折感和壓力。此外,這可能還意味著較低的fpga利用率,甚至錯過產(chǎn)品面市機會。
planahead 工具
越來越多的客戶在賽靈思 planahead 設(shè)計分析工具提供的層次化設(shè)計方法學中找到解決方案。planahead 軟件為 fpga 設(shè)計流程增加了可視性和可控性。通過解決物理方面(介于邏輯綜合和實現(xiàn)工藝之間)的問題,可在設(shè)計結(jié)果中實現(xiàn)性能的提高。
雖然先進的 fpga 綜合產(chǎn)品為幾百萬門設(shè)計提供極高的自動優(yōu)化水平,許多設(shè)計者仍需要具有更多啟發(fā)性的技術(shù),以達到最佳性能目標。通過提供早期分析和布局規(guī)劃 (floorplanning)功能,planahead 設(shè)計工具可以施加物理約束,以幫助控制設(shè)計的初始實現(xiàn)。實現(xiàn)后,planahead 軟件可以分析布局和時序結(jié)果,以改進用于完成設(shè)計的布局規(guī)劃??梢允褂脕碜詫虢Y(jié)果的物理約束,在后續(xù)實現(xiàn)嘗試期間鎖定布局。這些約束用于創(chuàng)建可重用 ip,連同鎖定布局,一同用于其它設(shè)計。
planahead 設(shè)計方法提供了性能、生產(chǎn)率以及結(jié)果的可重復性。憑借其層次化設(shè)計流程,planahead 軟件可減少運行 par 然后返回 rtl 與綜合的反復次數(shù)。反之,可以分析設(shè)計并在實現(xiàn)之前解決物理方面的問題。
速度更快,性能更好
planahead 用戶通??梢詫崿F(xiàn) 10-15% 的性能提升,有些用戶甚至可以更高。此外,設(shè)計者可以在一個緊湊的器件中額外加入 10% 的邏輯。更快的性能與更高利用率的結(jié)合意味著可以使用尺寸更小、成本更低的器件,或者以更低的速度等級實現(xiàn)設(shè)計目標。
planahead 設(shè)計工具可在縮短總設(shè)計時間的同時,在結(jié)果中增加一定的一致性。通過利用以前的布局規(guī)劃或增量設(shè)計技術(shù),可以以更少的時間執(zhí)行設(shè)計反復,實現(xiàn)可重復的結(jié)果。還可以利用成功結(jié)果,將它們鎖定下來或在其它設(shè)計中重用。
解決真正棘手的性能問題所需要的絕不僅僅是增加新的菜單項或腳本能力。planahead 軟件通過使用各種視圖(見圖 1)展示設(shè)計數(shù)據(jù),提供了一個完整的環(huán)境,使該層次化方法實現(xiàn)交互并易于使用。這些獨立的視圖可以相互結(jié)合使用,從而允許快速識別和瀏覽關(guān)鍵設(shè)計對象和信息。
還可顯示時鐘區(qū),并在布局規(guī)劃時使用它來優(yōu)化各個時鐘或最大程度地降低器件中的功耗。通過將時鐘隔離到專門的時鐘區(qū),它們可以運行得更快,并消除了為其它時鐘區(qū)供電的需要。
在設(shè)計過程中的各個階段均可使用 planahead 設(shè)計工具的分析和探測環(huán)境。甚至,可以在實現(xiàn)之前分析設(shè)計。
planahead 軟件提供了一個靜態(tài)時序引擎 timeahead,用于研究設(shè)計在時序方面的可行性。還可以通過調(diào)整純邏輯延遲,在不進行互連的情況下,使用估計的布線延遲執(zhí)行分析。這可以看清楚設(shè)計中存在多大的時序容差。
可視化
planahead 環(huán)境通過顯示 i/o 互連和物理塊(pblock)網(wǎng)束 (net bundle),提供洞察設(shè)計數(shù)據(jù)流的能力??梢愿鶕?jù)信號數(shù)量控制網(wǎng)束的顏色和線厚,方便地在貫穿設(shè)計的整個數(shù)據(jù)流中確定具有大量連接的 pblock。然后采取校正措施,避開布線擁塞故障點,并將具有大量連接的 pblock 相近放置或?qū)⑺鼈兒喜ⅰ?/p>
可在 planahead 環(huán)境中編輯和精調(diào)時序約束,相同的分析結(jié)果可以幫助確定哪些邏輯應(yīng)組合在一起并進行布局規(guī)劃。針對布局規(guī)劃,可對路徑進行邏輯排序、組合和選擇,還可以使用同一 timeahead 環(huán)境處理從 trce 導入的時序結(jié)果,trce 是賽靈思 ise軟件中的時序評估工具。
可以查看和修改為設(shè)計指定的時序約束。并可以在編輯器中將所有 ise 時序約束定義為新約束。這可以使約束指定變得更容易,不必再記住專門的約束格式??梢栽谶\行任何 ise 實現(xiàn)工具之前,將其與 timeahead 一起使用以驗證和優(yōu)化約束集。
planahead設(shè)計工具提供了可視輔助,以幫助理解物理實現(xiàn)結(jié)果。設(shè)計規(guī)則檢查 (drc) 功能有助于及早捕獲錯誤。它還會對未正確利用某些器件資源(如 virtex-4 fpga 中的 xtremedsp切片或 ram)的設(shè)計進行標記。
通過將問題區(qū)域可視化,可以在 rtl 側(cè)或物理實現(xiàn)側(cè)快速解決問題,而不必繼續(xù)重復進行 rtl 與綜合??梢詫Ω鱾€邏輯模塊進行選擇性地高亮顯示,以更好地了解它們放置的位置以及創(chuàng)建在邏輯最集中區(qū)域的pblock。此外,可以高亮顯示故障時序路徑,以可視化和了解設(shè)計中發(fā)生了什么物理問題。
planahead 軟件包含量度圖 (metric map),以快速確定設(shè)計的故障區(qū)域(見圖 2)。
這可能與時序或利用率有關(guān),有助于在試圖確定設(shè)計中要關(guān)注的區(qū)域以實現(xiàn)邏輯壓縮或時序連接性。
planahead 設(shè)計工具允許研究設(shè)計中的連接性。在設(shè)計中選擇一個特定的網(wǎng)絡(luò)、pblock 或?qū)嵗?,通過單擊鼠標高亮顯示所有連接到選定元素的網(wǎng)絡(luò)。
在選擇一個實例或 pblock 后,所有連接到該元素的網(wǎng)絡(luò)都將被高亮顯示。這一過程可以繼續(xù),以選擇和擴展邏輯錐形。運行"顯示連接性"將高亮顯示連接到選定實例的下一級網(wǎng)絡(luò)。這是一種選擇從某個特定實例或 i/o 端口開始的邏輯錐區(qū)的簡易方法,從而可真正實現(xiàn)對設(shè)計層次優(yōu)勢的利用。
解決性能問題
整個方案是要提供一個綜合環(huán)境,以分析時序問題并輕松約束邏輯以避免或糾正問題??墒褂脕碜?timeahead 或 trce 的時序結(jié)果進行布局規(guī)劃,通過幫助確定哪些邏輯應(yīng)組合在一起并進行布局規(guī)劃進行更好的性能設(shè)計。
關(guān)鍵路徑通常穿越邏輯層次。planahead 軟件支持獨立于邏輯層次的物理層次,從而使您可將設(shè)計中任意位置的邏輯組合在一起并有效地進行布局規(guī)劃。
planahead 軟件還提供了資源利用估算功能,以幫助確定 pblock 的尺寸和形狀。同樣這些統(tǒng)計資料還可報告時鐘信息、供應(yīng)鏈和 prm 適應(yīng)尺寸以及各種其它信息。
planahead 設(shè)計工具提供了自動布局能力,如基于邏輯層次的自動分區(qū)和自動 pblock 尺寸確定與放置。由于使用單個 pblock 矩形來包含所需的器件資源通常很困難,因此可以使用多個矩形創(chuàng)建非矩形-線性形狀。planahead 軟件還允許在 pblock 內(nèi)創(chuàng)建 pblock,或創(chuàng)建"子"pblock,以幫助更好地維護設(shè)計層次。
器件容量可通過壓縮 pblock 的邏輯進行提高。一種方法是使用稱為 compression 的賽靈思 area_group 屬性。area_group 是一種設(shè)計實現(xiàn)約束,支持將設(shè)計分成用于映射、打包、布局和布線的物理區(qū)域。使用 compression 屬性將導致 ise mapper 將無關(guān)的邏輯打包成未使用的 clb 站。使用它時請小心,因為它會對時序產(chǎn)生副作用。 改善性能的最佳策略是壓縮非時序關(guān)鍵型邏輯,從而在器件中騰出更多空間用于時序關(guān)鍵型邏輯。第二種選項是使用 planahead 功能在 pblock 上獨立運行 par。 可以持續(xù)縮減 pblock 尺寸,直到 par 失敗。這將盡可能緊密地壓縮和打包塊內(nèi)邏輯,以騰出器件空間。
一個 virtex-4 布局規(guī)劃示例
planahead 設(shè)計工具可輕松地導入布局和時序結(jié)果。通過該信息,可以查看和排序時序報告中的關(guān)鍵路徑,并使用原理圖或器件視圖對路徑進行可視化顯示。一旦確定故障路徑,可以高亮顯示布局規(guī)劃中的所有路徑實例,以確定原理圖視圖中的所有路徑實例。
在顯示中,高亮顯示了一條特定路徑上未能滿足時序要求的觸發(fā)器。由于它們在器件中分布太廣,設(shè)計實現(xiàn)產(chǎn)生了無法接受的長延遲。由于在 virtex-4
fpga 中存在大量的時序域,因此這是一種普遍情況。
通過選擇這些觸發(fā)器中的每個觸發(fā)器,并將它們限制到單個 pblock 中,可以調(diào)節(jié)和優(yōu)化該 pblock的尺寸和位置,從而縮短關(guān)鍵路徑的延遲,如圖 4 所示。
圖 4 在對與該路徑相關(guān)的 所有基元進行約束后, 您可以對 pblock 進行 優(yōu)化,以使該路徑達到 所需的時序要求
必要時,甚至可以創(chuàng)建嵌套 pblock,從而創(chuàng)建一種子/主層次來進一步約束子模塊,以獲得額外的性能提升。根據(jù)捕獲邏輯的資源需求,可以將關(guān)鍵邏輯鎖定位置,以實現(xiàn)對必要資源的最佳訪問。
評論